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

io.debezium.ddl.parser.mariadb.generated.MariaDBParser Maven / Gradle / Ivy

There is a newer version: 3.0.2.Final
Show newest version
// Generated from io/debezium/ddl/parser/mariadb/generated/MariaDBParser.g4 by ANTLR 4.10.1
package io.debezium.ddl.parser.mariadb.generated;
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"})
public class MariaDBParser extends Parser {
	static { RuntimeMetaData.checkVersion("4.10.1", 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, BODY=17, BOTH=18, BUCKETS=19, BY=20, 
		CALL=21, CASCADE=22, CASE=23, CAST=24, CHANGE=25, CHARACTER=26, CHECK=27, 
		COLLATE=28, COLUMN=29, CONDITION=30, CONSTRAINT=31, CONTINUE=32, CONVERT=33, 
		CREATE=34, CROSS=35, CURRENT=36, CURRENT_ROLE=37, CURRENT_USER=38, CURSOR=39, 
		DATABASE=40, DATABASES=41, DECLARE=42, DEFAULT=43, DELAYED=44, DELETE=45, 
		DESC=46, DESCRIBE=47, DETERMINISTIC=48, DIAGNOSTICS=49, DISTINCT=50, DISTINCTROW=51, 
		DROP=52, EACH=53, ELSE=54, ELSEIF=55, EMPTY=56, ENCLOSED=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, PACKAGE=131, PROCEDURE=132, PURGE=133, RANGE=134, 
		READ=135, READS=136, REFERENCES=137, REGEXP=138, RELEASE=139, RENAME=140, 
		REPEAT=141, REPLACE=142, REQUIRE=143, RESIGNAL=144, RESTRICT=145, RETAIN=146, 
		RETURN=147, REVOKE=148, RIGHT=149, RLIKE=150, SCHEMA=151, SCHEMAS=152, 
		SELECT=153, SET=154, SEPARATOR=155, SHOW=156, SIGNAL=157, SKIP_=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, LOCALES=475, 
		LOGFILE=476, LOGS=477, MASTER=478, MASTER_AUTO_POSITION=479, MASTER_CONNECT_RETRY=480, 
		MASTER_DELAY=481, MASTER_HEARTBEAT_PERIOD=482, MASTER_HOST=483, MASTER_LOG_FILE=484, 
		MASTER_LOG_POS=485, MASTER_PASSWORD=486, MASTER_PORT=487, MASTER_RETRY_COUNT=488, 
		MASTER_SSL=489, MASTER_SSL_CA=490, MASTER_SSL_CAPATH=491, MASTER_SSL_CERT=492, 
		MASTER_SSL_CIPHER=493, MASTER_SSL_CRL=494, MASTER_SSL_CRLPATH=495, MASTER_SSL_KEY=496, 
		MASTER_TLS_VERSION=497, MASTER_USER=498, MAX_CONNECTIONS_PER_HOUR=499, 
		MAX_QUERIES_PER_HOUR=500, MAX_ROWS=501, MAX_SIZE=502, MAX_UPDATES_PER_HOUR=503, 
		MAX_USER_CONNECTIONS=504, MEDIUM=505, MEMBER=506, MERGE=507, MESSAGE_TEXT=508, 
		MID=509, MIGRATE=510, MIN_ROWS=511, MODE=512, MODIFY=513, MUTEX=514, MYSQL=515, 
		MYSQL_ERRNO=516, NAME=517, NAMES=518, NCHAR=519, NEVER=520, NEXT=521, 
		NO=522, NOCACHE=523, NOCOPY=524, NOCYCLE=525, NOMAXVALUE=526, NOMINVALUE=527, 
		NOWAIT=528, NODEGROUP=529, NONE=530, ODBC=531, OFFLINE=532, OFFSET=533, 
		OF=534, OJ=535, OLD_PASSWORD=536, ONE=537, ONLINE=538, ONLY=539, OPEN=540, 
		OPTIMIZER_COSTS=541, OPTIONS=542, OWNER=543, PACK_KEYS=544, PAGE=545, 
		PAGE_COMPRESSED=546, PAGE_COMPRESSION_LEVEL=547, PARSER=548, PARTIAL=549, 
		PARTITIONING=550, PARTITIONS=551, PASSWORD=552, PASSWORD_LOCK_TIME=553, 
		PHASE=554, PLUGIN=555, PLUGIN_DIR=556, PLUGINS=557, PORT=558, PRECEDES=559, 
		PRECEDING=560, PREPARE=561, PRESERVE=562, PREV=563, PROCESSLIST=564, PROFILE=565, 
		PROFILES=566, PROXY=567, QUERY=568, QUERY_RESPONSE_TIME=569, QUICK=570, 
		REBUILD=571, RECOVER=572, RECURSIVE=573, REDO_BUFFER_SIZE=574, REDUNDANT=575, 
		RELAY=576, RELAY_LOG_FILE=577, RELAY_LOG_POS=578, RELAYLOG=579, REMOVE=580, 
		REORGANIZE=581, REPAIR=582, REPLICATE_DO_DB=583, REPLICATE_DO_TABLE=584, 
		REPLICATE_IGNORE_DB=585, REPLICATE_IGNORE_TABLE=586, REPLICATE_REWRITE_DB=587, 
		REPLICATE_WILD_DO_TABLE=588, REPLICATE_WILD_IGNORE_TABLE=589, REPLICATION=590, 
		RESET=591, RESTART=592, RESUME=593, RETURNED_SQLSTATE=594, RETURNING=595, 
		RETURNS=596, REUSE=597, ROLE=598, ROLLBACK=599, ROLLUP=600, ROTATE=601, 
		ROW=602, ROWS=603, ROW_FORMAT=604, RTREE=605, SAVEPOINT=606, SCHEDULE=607, 
		SECURITY=608, SEQUENCE=609, SERVER=610, SESSION=611, SHARE=612, SHARED=613, 
		SIGNED=614, SIMPLE=615, SLAVE=616, SLAVES=617, SLOW=618, SNAPSHOT=619, 
		SOCKET=620, SOME=621, SONAME=622, SOUNDS=623, SOURCE=624, SQL_AFTER_GTIDS=625, 
		SQL_AFTER_MTS_GAPS=626, SQL_BEFORE_GTIDS=627, SQL_BUFFER_RESULT=628, SQL_CACHE=629, 
		SQL_NO_CACHE=630, SQL_THREAD=631, START=632, STARTS=633, STATS_AUTO_RECALC=634, 
		STATS_PERSISTENT=635, STATS_SAMPLE_PAGES=636, STATUS=637, STOP=638, STORAGE=639, 
		STORED=640, STRING=641, SUBCLASS_ORIGIN=642, SUBJECT=643, SUBPARTITION=644, 
		SUBPARTITIONS=645, SUSPEND=646, SWAPS=647, SWITCHES=648, TABLE_NAME=649, 
		TABLESPACE=650, TABLE_TYPE=651, TEMPORARY=652, TEMPTABLE=653, THAN=654, 
		TRADITIONAL=655, TRANSACTION=656, TRANSACTIONAL=657, TRIGGERS=658, TRUNCATE=659, 
		TYPES=660, UNBOUNDED=661, UNDEFINED=662, UNDOFILE=663, UNDO_BUFFER_SIZE=664, 
		UNINSTALL=665, UNKNOWN=666, UNTIL=667, UPGRADE=668, USER=669, USE_FRM=670, 
		USER_RESOURCES=671, VALIDATION=672, VALUE=673, VARIABLES=674, VIEW=675, 
		VIRTUAL=676, VISIBLE=677, WAIT=678, WARNINGS=679, WINDOW=680, WITHOUT=681, 
		WORK=682, WRAPPER=683, WSREP_MEMBERSHIP=684, WSREP_STATUS=685, X509=686, 
		XA=687, XML=688, YES=689, EUR=690, USA=691, JIS=692, ISO=693, INTERNAL=694, 
		QUARTER=695, MONTH=696, DAY=697, HOUR=698, MINUTE=699, WEEK=700, SECOND=701, 
		MICROSECOND=702, USER_STATISTICS=703, CLIENT_STATISTICS=704, INDEX_STATISTICS=705, 
		TABLE_STATISTICS=706, ADMIN=707, APPLICATION_PASSWORD_ADMIN=708, AUDIT_ADMIN=709, 
		BACKUP_ADMIN=710, BINLOG_ADMIN=711, BINLOG_ENCRYPTION_ADMIN=712, CLONE_ADMIN=713, 
		CONNECTION_ADMIN=714, ENCRYPTION_KEY_ADMIN=715, EXECUTE=716, FILE=717, 
		FIREWALL_ADMIN=718, FIREWALL_USER=719, FLUSH_OPTIMIZER_COSTS=720, FLUSH_STATUS=721, 
		FLUSH_TABLES=722, FLUSH_USER_RESOURCES=723, GROUP_REPLICATION_ADMIN=724, 
		INNODB_REDO_LOG_ARCHIVE=725, INNODB_REDO_LOG_ENABLE=726, INVOKE=727, LAMBDA=728, 
		NDB_STORED_USER=729, PASSWORDLESS_USER_ADMIN=730, PERSIST_RO_VARIABLES_ADMIN=731, 
		PRIVILEGES=732, PROCESS=733, RELOAD=734, REPLICATION_APPLIER=735, REPLICATION_SLAVE_ADMIN=736, 
		RESOURCE_GROUP_ADMIN=737, RESOURCE_GROUP_USER=738, ROLE_ADMIN=739, ROUTINE=740, 
		S3=741, SERVICE_CONNECTION_ADMIN=742, SESSION_VARIABLES_ADMIN=743, SET_USER_ID=744, 
		SHOW_ROUTINE=745, SHUTDOWN=746, SUPER=747, SYSTEM_VARIABLES_ADMIN=748, 
		TABLES=749, TABLE_ENCRYPTION_ADMIN=750, VERSION_TOKEN_ADMIN=751, XA_RECOVER_ADMIN=752, 
		ARMSCII8=753, ASCII=754, BIG5=755, CP1250=756, CP1251=757, CP1256=758, 
		CP1257=759, CP850=760, CP852=761, CP866=762, CP932=763, DEC8=764, EUCJPMS=765, 
		EUCKR=766, GB18030=767, GB2312=768, GBK=769, GEOSTD8=770, GREEK=771, HEBREW=772, 
		HP8=773, KEYBCS2=774, KOI8R=775, KOI8U=776, LATIN1=777, LATIN2=778, LATIN5=779, 
		LATIN7=780, MACCE=781, MACROMAN=782, SJIS=783, SWE7=784, TIS620=785, UCS2=786, 
		UJIS=787, UTF16=788, UTF16LE=789, UTF32=790, UTF8=791, UTF8MB3=792, UTF8MB4=793, 
		ARCHIVE=794, BLACKHOLE=795, CSV=796, FEDERATED=797, INNODB=798, MEMORY=799, 
		MRG_MYISAM=800, MYISAM=801, NDB=802, NDBCLUSTER=803, PERFORMANCE_SCHEMA=804, 
		TOKUDB=805, REPEATABLE=806, COMMITTED=807, UNCOMMITTED=808, SERIALIZABLE=809, 
		GEOMETRYCOLLECTION=810, GEOMCOLLECTION=811, GEOMETRY=812, LINESTRING=813, 
		MULTILINESTRING=814, MULTIPOINT=815, MULTIPOLYGON=816, POINT=817, POLYGON=818, 
		ABS=819, ACOS=820, ADDDATE=821, ADDTIME=822, AES_DECRYPT=823, AES_ENCRYPT=824, 
		AREA=825, ASBINARY=826, ASIN=827, ASTEXT=828, ASWKB=829, ASWKT=830, ASYMMETRIC_DECRYPT=831, 
		ASYMMETRIC_DERIVE=832, ASYMMETRIC_ENCRYPT=833, ASYMMETRIC_SIGN=834, ASYMMETRIC_VERIFY=835, 
		ATAN=836, ATAN2=837, BENCHMARK=838, BIN=839, BIT_COUNT=840, BIT_LENGTH=841, 
		BUFFER=842, CATALOG_NAME=843, CEIL=844, CEILING=845, CENTROID=846, CHARACTER_LENGTH=847, 
		CHARSET=848, CHAR_LENGTH=849, COERCIBILITY=850, COLLATION=851, COMPRESS=852, 
		CONCAT=853, CONCAT_WS=854, CONNECTION_ID=855, CONV=856, CONVERT_TZ=857, 
		COS=858, COT=859, CRC32=860, CREATE_ASYMMETRIC_PRIV_KEY=861, CREATE_ASYMMETRIC_PUB_KEY=862, 
		CREATE_DH_PARAMETERS=863, CREATE_DIGEST=864, CROSSES=865, DATEDIFF=866, 
		DATE_FORMAT=867, DAYNAME=868, DAYOFMONTH=869, DAYOFWEEK=870, DAYOFYEAR=871, 
		DECODE=872, DEGREES=873, DES_DECRYPT=874, DES_ENCRYPT=875, DIMENSION=876, 
		DISJOINT=877, ELT=878, ENCODE=879, ENCRYPT=880, ENDPOINT=881, ENGINE_ATTRIBUTE=882, 
		ENVELOPE=883, EQUALS=884, EXP=885, EXPORT_SET=886, EXTERIORRING=887, EXTRACTVALUE=888, 
		FIELD=889, FIND_IN_SET=890, FLOOR=891, FORMAT=892, FOUND_ROWS=893, FROM_BASE64=894, 
		FROM_DAYS=895, FROM_UNIXTIME=896, GEOMCOLLFROMTEXT=897, GEOMCOLLFROMWKB=898, 
		GEOMETRYCOLLECTIONFROMTEXT=899, GEOMETRYCOLLECTIONFROMWKB=900, GEOMETRYFROMTEXT=901, 
		GEOMETRYFROMWKB=902, GEOMETRYN=903, GEOMETRYTYPE=904, GEOMFROMTEXT=905, 
		GEOMFROMWKB=906, GET_FORMAT=907, GET_LOCK=908, GLENGTH=909, GREATEST=910, 
		GTID_SUBSET=911, GTID_SUBTRACT=912, HEX=913, IFNULL=914, INET6_ATON=915, 
		INET6_NTOA=916, INET_ATON=917, INET_NTOA=918, INSTR=919, INTERIORRINGN=920, 
		INTERSECTS=921, ISCLOSED=922, ISEMPTY=923, ISNULL=924, ISSIMPLE=925, IS_FREE_LOCK=926, 
		IS_IPV4=927, IS_IPV4_COMPAT=928, IS_IPV4_MAPPED=929, IS_IPV6=930, IS_USED_LOCK=931, 
		LAST_INSERT_ID=932, LCASE=933, LEAST=934, LENGTH=935, LINEFROMTEXT=936, 
		LINEFROMWKB=937, LINESTRINGFROMTEXT=938, LINESTRINGFROMWKB=939, LN=940, 
		LOAD_FILE=941, LOCATE=942, LOG=943, LOG10=944, LOG2=945, LOWER=946, LPAD=947, 
		LTRIM=948, MAKEDATE=949, MAKETIME=950, MAKE_SET=951, MASTER_POS_WAIT=952, 
		MBRCONTAINS=953, MBRDISJOINT=954, MBREQUAL=955, MBRINTERSECTS=956, MBROVERLAPS=957, 
		MBRTOUCHES=958, MBRWITHIN=959, MD5=960, MLINEFROMTEXT=961, MLINEFROMWKB=962, 
		MONTHNAME=963, MPOINTFROMTEXT=964, MPOINTFROMWKB=965, MPOLYFROMTEXT=966, 
		MPOLYFROMWKB=967, MULTILINESTRINGFROMTEXT=968, MULTILINESTRINGFROMWKB=969, 
		MULTIPOINTFROMTEXT=970, MULTIPOINTFROMWKB=971, MULTIPOLYGONFROMTEXT=972, 
		MULTIPOLYGONFROMWKB=973, NAME_CONST=974, NULLIF=975, NUMGEOMETRIES=976, 
		NUMINTERIORRINGS=977, NUMPOINTS=978, OCT=979, OCTET_LENGTH=980, ORD=981, 
		OVERLAPS=982, PERIOD_ADD=983, PERIOD_DIFF=984, PI=985, POINTFROMTEXT=986, 
		POINTFROMWKB=987, POINTN=988, POLYFROMTEXT=989, POLYFROMWKB=990, POLYGONFROMTEXT=991, 
		POLYGONFROMWKB=992, POW=993, POWER=994, QUOTE=995, RADIANS=996, RAND=997, 
		RANDOM_BYTES=998, RELEASE_LOCK=999, REVERSE=1000, ROUND=1001, ROW_COUNT=1002, 
		RPAD=1003, RTRIM=1004, SEC_TO_TIME=1005, SECONDARY_ENGINE_ATTRIBUTE=1006, 
		SESSION_USER=1007, SHA=1008, SHA1=1009, SHA2=1010, SCHEMA_NAME=1011, SIGN=1012, 
		SIN=1013, SLEEP=1014, SOUNDEX=1015, SQL_THREAD_WAIT_AFTER_GTIDS=1016, 
		SQRT=1017, SRID=1018, STARTPOINT=1019, STRCMP=1020, STR_TO_DATE=1021, 
		ST_AREA=1022, ST_ASBINARY=1023, ST_ASTEXT=1024, ST_ASWKB=1025, ST_ASWKT=1026, 
		ST_BUFFER=1027, ST_CENTROID=1028, ST_CONTAINS=1029, ST_CROSSES=1030, ST_DIFFERENCE=1031, 
		ST_DIMENSION=1032, ST_DISJOINT=1033, ST_DISTANCE=1034, ST_ENDPOINT=1035, 
		ST_ENVELOPE=1036, ST_EQUALS=1037, ST_EXTERIORRING=1038, ST_GEOMCOLLFROMTEXT=1039, 
		ST_GEOMCOLLFROMTXT=1040, ST_GEOMCOLLFROMWKB=1041, ST_GEOMETRYCOLLECTIONFROMTEXT=1042, 
		ST_GEOMETRYCOLLECTIONFROMWKB=1043, ST_GEOMETRYFROMTEXT=1044, ST_GEOMETRYFROMWKB=1045, 
		ST_GEOMETRYN=1046, ST_GEOMETRYTYPE=1047, ST_GEOMFROMTEXT=1048, ST_GEOMFROMWKB=1049, 
		ST_INTERIORRINGN=1050, ST_INTERSECTION=1051, ST_INTERSECTS=1052, ST_ISCLOSED=1053, 
		ST_ISEMPTY=1054, ST_ISSIMPLE=1055, ST_LINEFROMTEXT=1056, ST_LINEFROMWKB=1057, 
		ST_LINESTRINGFROMTEXT=1058, ST_LINESTRINGFROMWKB=1059, ST_NUMGEOMETRIES=1060, 
		ST_NUMINTERIORRING=1061, ST_NUMINTERIORRINGS=1062, ST_NUMPOINTS=1063, 
		ST_OVERLAPS=1064, ST_POINTFROMTEXT=1065, ST_POINTFROMWKB=1066, ST_POINTN=1067, 
		ST_POLYFROMTEXT=1068, ST_POLYFROMWKB=1069, ST_POLYGONFROMTEXT=1070, ST_POLYGONFROMWKB=1071, 
		ST_SRID=1072, ST_STARTPOINT=1073, ST_SYMDIFFERENCE=1074, ST_TOUCHES=1075, 
		ST_UNION=1076, ST_WITHIN=1077, ST_X=1078, ST_Y=1079, SUBDATE=1080, SUBSTRING_INDEX=1081, 
		SUBTIME=1082, SYSTEM_USER=1083, TAN=1084, TIMEDIFF=1085, TIMESTAMPADD=1086, 
		TIMESTAMPDIFF=1087, TIME_FORMAT=1088, TIME_TO_SEC=1089, TOUCHES=1090, 
		TO_BASE64=1091, TO_DAYS=1092, TO_SECONDS=1093, UCASE=1094, UNCOMPRESS=1095, 
		UNCOMPRESSED_LENGTH=1096, UNHEX=1097, UNIX_TIMESTAMP=1098, UPDATEXML=1099, 
		UPPER=1100, UUID=1101, UUID_SHORT=1102, VALIDATE_PASSWORD_STRENGTH=1103, 
		VERSION=1104, WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS=1105, WEEKDAY=1106, WEEKOFYEAR=1107, 
		WEIGHT_STRING=1108, WITHIN=1109, YEARWEEK=1110, Y_FUNCTION=1111, X_FUNCTION=1112, 
		VIA=1113, LASTVAL=1114, NEXTVAL=1115, SETVAL=1116, PREVIOUS=1117, PERSISTENT=1118, 
		BINLOG_MONITOR=1119, BINLOG_REPLAY=1120, FEDERATED_ADMIN=1121, READ_ONLY_ADMIN=1122, 
		REPLICA=1123, REPLICAS=1124, REPLICATION_MASTER_ADMIN=1125, MONITOR=1126, 
		READ_ONLY=1127, REPLAY=1128, VAR_ASSIGN=1129, PLUS_ASSIGN=1130, MINUS_ASSIGN=1131, 
		MULT_ASSIGN=1132, DIV_ASSIGN=1133, MOD_ASSIGN=1134, AND_ASSIGN=1135, XOR_ASSIGN=1136, 
		OR_ASSIGN=1137, STAR=1138, DIVIDE=1139, MODULE=1140, PLUS=1141, MINUS=1142, 
		DIV=1143, MOD=1144, EQUAL_SYMBOL=1145, GREATER_SYMBOL=1146, LESS_SYMBOL=1147, 
		EXCLAMATION_SYMBOL=1148, BIT_NOT_OP=1149, BIT_OR_OP=1150, BIT_AND_OP=1151, 
		BIT_XOR_OP=1152, DOT=1153, LR_BRACKET=1154, RR_BRACKET=1155, COMMA=1156, 
		SEMI=1157, AT_SIGN=1158, ZERO_DECIMAL=1159, ONE_DECIMAL=1160, TWO_DECIMAL=1161, 
		SINGLE_QUOTE_SYMB=1162, DOUBLE_QUOTE_SYMB=1163, REVERSE_QUOTE_SYMB=1164, 
		COLON_SYMB=1165, CHARSET_REVERSE_QOUTE_STRING=1166, FILESIZE_LITERAL=1167, 
		START_NATIONAL_STRING_LITERAL=1168, STRING_LITERAL=1169, DECIMAL_LITERAL=1170, 
		HEXADECIMAL_LITERAL=1171, REAL_LITERAL=1172, NULL_SPEC_LITERAL=1173, BIT_STRING=1174, 
		STRING_CHARSET_NAME=1175, DOT_ID=1176, ID=1177, REVERSE_QUOTE_ID=1178, 
		HOST_IP_ADDRESS=1179, LOCAL_ID=1180, GLOBAL_ID=1181, ERROR_RECONGNIGION=1182;
	public static final int
		RULE_root = 0, RULE_sqlStatements = 1, RULE_sqlStatement = 2, RULE_setStatementFor = 3, 
		RULE_emptyStatement_ = 4, RULE_ddlStatement = 5, RULE_dmlStatement = 6, 
		RULE_transactionStatement = 7, RULE_replicationStatement = 8, RULE_preparedStatement = 9, 
		RULE_compoundStatement = 10, RULE_administrationStatement = 11, RULE_utilityStatement = 12, 
		RULE_createDatabase = 13, RULE_createEvent = 14, RULE_createIndex = 15, 
		RULE_createLogfileGroup = 16, RULE_createProcedure = 17, RULE_createFunction = 18, 
		RULE_createRole = 19, RULE_createServer = 20, RULE_createTable = 21, RULE_createTablespaceInnodb = 22, 
		RULE_createTablespaceNdb = 23, RULE_createTrigger = 24, RULE_withClause = 25, 
		RULE_commonTableExpressions = 26, RULE_cteName = 27, RULE_cteColumnName = 28, 
		RULE_createView = 29, RULE_createSequence = 30, RULE_sequenceSpec = 31, 
		RULE_createDatabaseOption = 32, RULE_charSet = 33, RULE_currentUserExpression = 34, 
		RULE_ownerStatement = 35, RULE_scheduleExpression = 36, RULE_timestampValue = 37, 
		RULE_intervalExpr = 38, RULE_intervalType = 39, RULE_enableType = 40, 
		RULE_indexType = 41, RULE_indexOption = 42, RULE_procedureParameter = 43, 
		RULE_functionParameter = 44, RULE_routineOption = 45, RULE_serverOption = 46, 
		RULE_createDefinitions = 47, RULE_createDefinition = 48, RULE_columnDefinition = 49, 
		RULE_columnConstraint = 50, RULE_tableConstraint = 51, RULE_referenceDefinition = 52, 
		RULE_referenceAction = 53, RULE_referenceControlType = 54, RULE_indexColumnDefinition = 55, 
		RULE_tableOption = 56, RULE_tableType = 57, RULE_tablespaceStorage = 58, 
		RULE_partitionDefinitions = 59, RULE_partitionFunctionDefinition = 60, 
		RULE_subpartitionFunctionDefinition = 61, RULE_partitionDefinition = 62, 
		RULE_partitionDefinerAtom = 63, RULE_partitionDefinerVector = 64, RULE_subpartitionDefinition = 65, 
		RULE_partitionOption = 66, RULE_alterDatabase = 67, RULE_alterEvent = 68, 
		RULE_alterFunction = 69, RULE_alterInstance = 70, RULE_alterLogfileGroup = 71, 
		RULE_alterProcedure = 72, RULE_alterServer = 73, RULE_alterTable = 74, 
		RULE_alterTablespace = 75, RULE_alterView = 76, RULE_alterSequence = 77, 
		RULE_alterSpecification = 78, RULE_alterPartitionSpecification = 79, RULE_dropDatabase = 80, 
		RULE_dropEvent = 81, RULE_dropIndex = 82, RULE_dropLogfileGroup = 83, 
		RULE_dropProcedure = 84, RULE_dropFunction = 85, RULE_dropServer = 86, 
		RULE_dropTable = 87, RULE_dropTablespace = 88, RULE_dropTrigger = 89, 
		RULE_dropView = 90, RULE_dropRole = 91, RULE_setRole = 92, RULE_dropSequence = 93, 
		RULE_renameTable = 94, RULE_renameTableClause = 95, RULE_truncateTable = 96, 
		RULE_callStatement = 97, RULE_deleteStatement = 98, RULE_doStatement = 99, 
		RULE_handlerStatement = 100, RULE_insertStatement = 101, RULE_loadDataStatement = 102, 
		RULE_loadXmlStatement = 103, RULE_replaceStatement = 104, RULE_selectStatement = 105, 
		RULE_updateStatement = 106, RULE_valuesStatement = 107, RULE_insertStatementValue = 108, 
		RULE_updatedElement = 109, RULE_assignmentField = 110, RULE_lockClause = 111, 
		RULE_singleDeleteStatement = 112, RULE_multipleDeleteStatement = 113, 
		RULE_handlerOpenStatement = 114, RULE_handlerReadIndexStatement = 115, 
		RULE_handlerReadStatement = 116, RULE_handlerCloseStatement = 117, RULE_singleUpdateStatement = 118, 
		RULE_multipleUpdateStatement = 119, RULE_orderByClause = 120, RULE_orderByExpression = 121, 
		RULE_tableSources = 122, RULE_tableSource = 123, RULE_tableSourceItem = 124, 
		RULE_indexHint = 125, RULE_indexHintType = 126, RULE_joinPart = 127, RULE_queryExpression = 128, 
		RULE_queryExpressionNointo = 129, RULE_querySpecification = 130, RULE_querySpecificationNointo = 131, 
		RULE_unionParenthesis = 132, RULE_unionStatement = 133, RULE_lateralStatement = 134, 
		RULE_jsonTable = 135, RULE_jsonColumnList = 136, RULE_jsonColumn = 137, 
		RULE_jsonOnEmpty = 138, RULE_jsonOnError = 139, RULE_selectSpec = 140, 
		RULE_selectElements = 141, RULE_selectElement = 142, RULE_selectIntoExpression = 143, 
		RULE_selectFieldsInto = 144, RULE_selectLinesInto = 145, RULE_fromClause = 146, 
		RULE_groupByClause = 147, RULE_havingClause = 148, RULE_windowClause = 149, 
		RULE_groupByItem = 150, RULE_limitClause = 151, RULE_limitClauseAtom = 152, 
		RULE_startTransaction = 153, RULE_beginWork = 154, RULE_commitWork = 155, 
		RULE_rollbackWork = 156, RULE_savepointStatement = 157, RULE_rollbackStatement = 158, 
		RULE_releaseStatement = 159, RULE_lockTables = 160, RULE_unlockTables = 161, 
		RULE_setAutocommitStatement = 162, RULE_setTransactionStatement = 163, 
		RULE_transactionMode = 164, RULE_lockTableElement = 165, RULE_lockAction = 166, 
		RULE_transactionOption = 167, RULE_transactionLevel = 168, RULE_changeMaster = 169, 
		RULE_changeReplicationFilter = 170, RULE_purgeBinaryLogs = 171, RULE_resetMaster = 172, 
		RULE_resetSlave = 173, RULE_startSlave = 174, RULE_stopSlave = 175, RULE_startGroupReplication = 176, 
		RULE_stopGroupReplication = 177, RULE_masterOption = 178, RULE_stringMasterOption = 179, 
		RULE_decimalMasterOption = 180, RULE_boolMasterOption = 181, RULE_channelOption = 182, 
		RULE_replicationFilter = 183, RULE_tablePair = 184, RULE_threadType = 185, 
		RULE_untilOption = 186, RULE_connectionOption = 187, RULE_gtuidSet = 188, 
		RULE_xaStartTransaction = 189, RULE_xaEndTransaction = 190, RULE_xaPrepareStatement = 191, 
		RULE_xaCommitWork = 192, RULE_xaRollbackWork = 193, RULE_xaRecoverWork = 194, 
		RULE_prepareStatement = 195, RULE_executeStatement = 196, RULE_deallocatePrepare = 197, 
		RULE_routineBody = 198, RULE_blockStatement = 199, RULE_caseStatement = 200, 
		RULE_ifStatement = 201, RULE_iterateStatement = 202, RULE_leaveStatement = 203, 
		RULE_loopStatement = 204, RULE_repeatStatement = 205, RULE_returnStatement = 206, 
		RULE_whileStatement = 207, RULE_cursorStatement = 208, RULE_declareVariable = 209, 
		RULE_declareCondition = 210, RULE_declareCursor = 211, RULE_declareHandler = 212, 
		RULE_handlerConditionValue = 213, RULE_procedureSqlStatement = 214, RULE_caseAlternative = 215, 
		RULE_elifAlternative = 216, RULE_alterUser = 217, RULE_createUser = 218, 
		RULE_dropUser = 219, RULE_grantStatement = 220, RULE_roleOption = 221, 
		RULE_grantProxy = 222, RULE_renameUser = 223, RULE_revokeStatement = 224, 
		RULE_revokeProxy = 225, RULE_setPasswordStatement = 226, RULE_userSpecification = 227, 
		RULE_userAuthOption = 228, RULE_authenticationRule = 229, RULE_tlsOption = 230, 
		RULE_userResourceOption = 231, RULE_userPasswordOption = 232, RULE_userLockOption = 233, 
		RULE_privelegeClause = 234, RULE_privilege = 235, RULE_privilegeLevel = 236, 
		RULE_renameUserClause = 237, RULE_analyzeTable = 238, RULE_checkTable = 239, 
		RULE_checksumTable = 240, RULE_optimizeTable = 241, RULE_repairTable = 242, 
		RULE_checkTableOption = 243, RULE_createUdfunction = 244, RULE_installPlugin = 245, 
		RULE_uninstallPlugin = 246, RULE_setStatement = 247, RULE_showStatement = 248, 
		RULE_explainStatement = 249, RULE_variableClause = 250, RULE_showCommonEntity = 251, 
		RULE_showFilter = 252, RULE_showGlobalInfoClause = 253, RULE_showSchemaEntity = 254, 
		RULE_showProfileType = 255, RULE_binlogStatement = 256, RULE_cacheIndexStatement = 257, 
		RULE_flushStatement = 258, RULE_killStatement = 259, RULE_loadIndexIntoCache = 260, 
		RULE_resetStatement = 261, RULE_shutdownStatement = 262, RULE_tableIndexes = 263, 
		RULE_flushOption = 264, RULE_flushTableOption = 265, RULE_loadedTableIndexes = 266, 
		RULE_simpleDescribeStatement = 267, RULE_fullDescribeStatement = 268, 
		RULE_formatJsonStatement = 269, RULE_helpStatement = 270, RULE_useStatement = 271, 
		RULE_signalStatement = 272, RULE_resignalStatement = 273, RULE_signalConditionInformation = 274, 
		RULE_diagnosticsStatement = 275, RULE_diagnosticsConditionInformationName = 276, 
		RULE_describeObjectClause = 277, RULE_fullId = 278, RULE_tableName = 279, 
		RULE_roleName = 280, RULE_fullColumnName = 281, RULE_indexColumnName = 282, 
		RULE_simpleUserName = 283, RULE_hostName = 284, RULE_userName = 285, RULE_mysqlVariable = 286, 
		RULE_charsetName = 287, RULE_collationName = 288, RULE_engineName = 289, 
		RULE_engineNameBase = 290, RULE_encryptedLiteral = 291, RULE_uuidSet = 292, 
		RULE_xid = 293, RULE_xuidStringId = 294, RULE_authPlugin = 295, RULE_uid = 296, 
		RULE_simpleId = 297, RULE_dottedId = 298, RULE_decimalLiteral = 299, RULE_fileSizeLiteral = 300, 
		RULE_stringLiteral = 301, RULE_booleanLiteral = 302, RULE_hexadecimalLiteral = 303, 
		RULE_nullNotnull = 304, RULE_constant = 305, RULE_dataType = 306, RULE_collectionOptions = 307, 
		RULE_collectionOption = 308, RULE_convertedDataType = 309, RULE_lengthOneDimension = 310, 
		RULE_lengthTwoDimension = 311, RULE_lengthTwoOptionalDimension = 312, 
		RULE_uidList = 313, RULE_tables = 314, RULE_indexColumnNames = 315, RULE_expressions = 316, 
		RULE_expressionsWithDefaults = 317, RULE_constants = 318, RULE_simpleStrings = 319, 
		RULE_userVariables = 320, RULE_defaultValue = 321, RULE_currentTimestamp = 322, 
		RULE_expressionOrDefault = 323, RULE_ifExists = 324, RULE_ifNotExists = 325, 
		RULE_orReplace = 326, RULE_waitNowaitClause = 327, RULE_lockOption = 328, 
		RULE_functionCall = 329, RULE_specificFunction = 330, RULE_caseFuncAlternative = 331, 
		RULE_levelsInWeightString = 332, RULE_levelInWeightListElement = 333, 
		RULE_aggregateWindowedFunction = 334, RULE_nonAggregateWindowedFunction = 335, 
		RULE_overClause = 336, RULE_windowSpec = 337, RULE_windowName = 338, RULE_frameClause = 339, 
		RULE_frameUnits = 340, RULE_frameExtent = 341, RULE_frameBetween = 342, 
		RULE_frameRange = 343, RULE_partitionClause = 344, RULE_scalarFunctionName = 345, 
		RULE_passwordFunctionClause = 346, RULE_functionArgs = 347, RULE_functionArg = 348, 
		RULE_expression = 349, RULE_predicate = 350, RULE_expressionAtom = 351, 
		RULE_unaryOperator = 352, RULE_comparisonOperator = 353, RULE_logicalOperator = 354, 
		RULE_bitOperator = 355, RULE_mathOperator = 356, RULE_jsonOperator = 357, 
		RULE_charsetNameBase = 358, RULE_transactionLevelBase = 359, RULE_privilegesBase = 360, 
		RULE_intervalTypeBase = 361, RULE_dataTypeBase = 362, RULE_keywordsCanBeId = 363, 
		RULE_functionNameBase = 364;
	private static String[] makeRuleNames() {
		return new String[] {
			"root", "sqlStatements", "sqlStatement", "setStatementFor", "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", "createSequence", 
			"sequenceSpec", "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", "alterSequence", "alterSpecification", "alterPartitionSpecification", 
			"dropDatabase", "dropEvent", "dropIndex", "dropLogfileGroup", "dropProcedure", 
			"dropFunction", "dropServer", "dropTable", "dropTablespace", "dropTrigger", 
			"dropView", "dropRole", "setRole", "dropSequence", "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", 
			"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", "authenticationRule", 
			"tlsOption", "userResourceOption", "userPasswordOption", "userLockOption", 
			"privelegeClause", "privilege", "privilegeLevel", "renameUserClause", 
			"analyzeTable", "checkTable", "checksumTable", "optimizeTable", "repairTable", 
			"checkTableOption", "createUdfunction", "installPlugin", "uninstallPlugin", 
			"setStatement", "showStatement", "explainStatement", "variableClause", 
			"showCommonEntity", "showFilter", "showGlobalInfoClause", "showSchemaEntity", 
			"showProfileType", "binlogStatement", "cacheIndexStatement", "flushStatement", 
			"killStatement", "loadIndexIntoCache", "resetStatement", "shutdownStatement", 
			"tableIndexes", "flushOption", "flushTableOption", "loadedTableIndexes", 
			"simpleDescribeStatement", "fullDescribeStatement", "formatJsonStatement", 
			"helpStatement", "useStatement", "signalStatement", "resignalStatement", 
			"signalConditionInformation", "diagnosticsStatement", "diagnosticsConditionInformationName", 
			"describeObjectClause", "fullId", "tableName", "roleName", "fullColumnName", 
			"indexColumnName", "simpleUserName", "hostName", "userName", "mysqlVariable", 
			"charsetName", "collationName", "engineName", "engineNameBase", "encryptedLiteral", 
			"uuidSet", "xid", "xuidStringId", "authPlugin", "uid", "simpleId", "dottedId", 
			"decimalLiteral", "fileSizeLiteral", "stringLiteral", "booleanLiteral", 
			"hexadecimalLiteral", "nullNotnull", "constant", "dataType", "collectionOptions", 
			"collectionOption", "convertedDataType", "lengthOneDimension", "lengthTwoDimension", 
			"lengthTwoOptionalDimension", "uidList", "tables", "indexColumnNames", 
			"expressions", "expressionsWithDefaults", "constants", "simpleStrings", 
			"userVariables", "defaultValue", "currentTimestamp", "expressionOrDefault", 
			"ifExists", "ifNotExists", "orReplace", "waitNowaitClause", "lockOption", 
			"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", "mathOperator", "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'", "'BODY'", "'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'", "'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'", "'PACKAGE'", "'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'", "'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'", null, "'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'", "'LOCALES'", "'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'", "'QUERY_RESPONSE_TIME'", "'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'", 
			"'SLAVES'", "'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'", "'TYPES'", 
			"'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'", 
			"'WSREP_MEMBERSHIP'", "'WSREP_STATUS'", "'X509'", "'XA'", "'XML'", "'YES'", 
			"'EUR'", "'USA'", "'JIS'", "'ISO'", "'INTERNAL'", "'QUARTER'", "'MONTH'", 
			"'DAY'", "'HOUR'", "'MINUTE'", "'WEEK'", "'SECOND'", "'MICROSECOND'", 
			"'USER_STATISTICS'", "'CLIENT_STATISTICS'", "'INDEX_STATISTICS'", "'TABLE_STATISTICS'", 
			"'ADMIN'", "'APPLICATION_PASSWORD_ADMIN'", "'AUDIT_ADMIN'", "'BACKUP_ADMIN'", 
			"'BINLOG_ADMIN'", "'BINLOG_ENCRYPTION_ADMIN'", "'CLONE_ADMIN'", "'CONNECTION_ADMIN'", 
			"'ENCRYPTION_KEY_ADMIN'", "'EXECUTE'", "'FILE'", "'FIREWALL_ADMIN'", 
			"'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_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'", "'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'", "'VIA'", "'LASTVAL'", 
			"'NEXTVAL'", "'SETVAL'", "'PREVIOUS'", "'PERSISTENT'", "'BINLOG_MONITOR'", 
			"'BINLOG_REPLAY'", "'FEDERATED_ADMIN'", "'READ_ONLY_ADMIN'", "'REPLICA'", 
			"'REPLICAS'", "'REPLICATION_MASTER_ADMIN'", "'MONITOR'", "'READ_ONLY'", 
			"'REPLAY'", "':='", "'+='", "'-='", "'*='", "'/='", "'%='", "'&='", "'^='", 
			"'|='", "'*'", "'/'", "'%'", "'+'", "'-'", "'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", "BODY", "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", "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", "PACKAGE", 
			"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_", "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", "LOCALES", 
			"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", "QUERY_RESPONSE_TIME", "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", 
			"SLAVES", "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", "TYPES", "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", "WSREP_MEMBERSHIP", "WSREP_STATUS", "X509", "XA", "XML", "YES", 
			"EUR", "USA", "JIS", "ISO", "INTERNAL", "QUARTER", "MONTH", "DAY", "HOUR", 
			"MINUTE", "WEEK", "SECOND", "MICROSECOND", "USER_STATISTICS", "CLIENT_STATISTICS", 
			"INDEX_STATISTICS", "TABLE_STATISTICS", "ADMIN", "APPLICATION_PASSWORD_ADMIN", 
			"AUDIT_ADMIN", "BACKUP_ADMIN", "BINLOG_ADMIN", "BINLOG_ENCRYPTION_ADMIN", 
			"CLONE_ADMIN", "CONNECTION_ADMIN", "ENCRYPTION_KEY_ADMIN", "EXECUTE", 
			"FILE", "FIREWALL_ADMIN", "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_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", "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", "VIA", "LASTVAL", "NEXTVAL", "SETVAL", "PREVIOUS", "PERSISTENT", 
			"BINLOG_MONITOR", "BINLOG_REPLAY", "FEDERATED_ADMIN", "READ_ONLY_ADMIN", 
			"REPLICA", "REPLICAS", "REPLICATION_MASTER_ADMIN", "MONITOR", "READ_ONLY", 
			"REPLAY", "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 "MariaDBParser.g4"; }

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

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

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

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

	public static class RootContext extends ParserRuleContext {
		public TerminalNode EOF() { return getToken(MariaDBParser.EOF, 0); }
		public SqlStatementsContext sqlStatements() {
			return getRuleContext(SqlStatementsContext.class,0);
		}
		public List MINUS() { return getTokens(MariaDBParser.MINUS); }
		public TerminalNode MINUS(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRoot(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRoot(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(731);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << ALTER) | (1L << ANALYZE) | (1L << CALL) | (1L << CHANGE) | (1L << CHECK) | (1L << CREATE) | (1L << DELETE) | (1L << DESC) | (1L << DESCRIBE) | (1L << DROP) | (1L << EXPLAIN))) != 0) || ((((_la - 71)) & ~0x3f) == 0 && ((1L << (_la - 71)) & ((1L << (GET - 71)) | (1L << (GRANT - 71)) | (1L << (INSERT - 71)) | (1L << (KILL - 71)) | (1L << (LOAD - 71)) | (1L << (LOCK - 71)) | (1L << (OPTIMIZE - 71)) | (1L << (PURGE - 71)))) != 0) || ((((_la - 139)) & ~0x3f) == 0 && ((1L << (_la - 139)) & ((1L << (RELEASE - 139)) | (1L << (RENAME - 139)) | (1L << (REPLACE - 139)) | (1L << (RESIGNAL - 139)) | (1L << (REVOKE - 139)) | (1L << (SELECT - 139)) | (1L << (SET - 139)) | (1L << (SHOW - 139)) | (1L << (SIGNAL - 139)) | (1L << (UNLOCK - 139)) | (1L << (UPDATE - 139)) | (1L << (USE - 139)) | (1L << (VALUES - 139)))) != 0) || ((((_la - 344)) & ~0x3f) == 0 && ((1L << (_la - 344)) & ((1L << (BEGIN - 344)) | (1L << (BINLOG - 344)) | (1L << (CACHE - 344)) | (1L << (CHECKSUM - 344)) | (1L << (COMMIT - 344)) | (1L << (DEALLOCATE - 344)) | (1L << (DO - 344)))) != 0) || ((((_la - 432)) & ~0x3f) == 0 && ((1L << (_la - 432)) & ((1L << (FLUSH - 432)) | (1L << (HANDLER - 432)) | (1L << (HELP - 432)) | (1L << (INSTALL - 432)))) != 0) || ((((_la - 561)) & ~0x3f) == 0 && ((1L << (_la - 561)) & ((1L << (PREPARE - 561)) | (1L << (REPAIR - 561)) | (1L << (RESET - 561)) | (1L << (ROLLBACK - 561)) | (1L << (SAVEPOINT - 561)))) != 0) || ((((_la - 632)) & ~0x3f) == 0 && ((1L << (_la - 632)) & ((1L << (START - 632)) | (1L << (STOP - 632)) | (1L << (TRUNCATE - 632)) | (1L << (UNINSTALL - 632)) | (1L << (XA - 632)))) != 0) || _la==EXECUTE || _la==SHUTDOWN || _la==LR_BRACKET || _la==SEMI) {
				{
				setState(730);
				sqlStatements();
				}
			}

			setState(735);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==MINUS) {
				{
				setState(733);
				match(MINUS);
				setState(734);
				match(MINUS);
				}
			}

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

	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(MariaDBParser.SEMI); }
		public TerminalNode SEMI(int i) {
			return getToken(MariaDBParser.SEMI, i);
		}
		public List MINUS() { return getTokens(MariaDBParser.MINUS); }
		public TerminalNode MINUS(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSqlStatements(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSqlStatements(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(750);
			_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(748);
					_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 UNLOCK:
					case UPDATE:
					case USE:
					case VALUES:
					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(739);
						sqlStatement();
						setState(742);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==MINUS) {
							{
							setState(740);
							match(MINUS);
							setState(741);
							match(MINUS);
							}
						}

						setState(745);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,3,_ctx) ) {
						case 1:
							{
							setState(744);
							match(SEMI);
							}
							break;
						}
						}
						break;
					case SEMI:
						{
						setState(747);
						emptyStatement_();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					} 
				}
				setState(752);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,5,_ctx);
			}
			setState(762);
			_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 UNLOCK:
			case UPDATE:
			case USE:
			case VALUES:
			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(753);
				sqlStatement();
				setState(759);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,7,_ctx) ) {
				case 1:
					{
					setState(756);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==MINUS) {
						{
						setState(754);
						match(MINUS);
						setState(755);
						match(MINUS);
						}
					}

					setState(758);
					match(SEMI);
					}
					break;
				}
				}
				break;
			case SEMI:
				{
				setState(761);
				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;
	}

	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 SetStatementForContext setStatementFor() {
			return getRuleContext(SetStatementForContext.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSqlStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSqlStatement(this);
		}
	}

	public final SqlStatementContext sqlStatement() throws RecognitionException {
		SqlStatementContext _localctx = new SqlStatementContext(_ctx, getState());
		enterRule(_localctx, 4, RULE_sqlStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(765);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,9,_ctx) ) {
			case 1:
				{
				setState(764);
				setStatementFor();
				}
				break;
			}
			setState(774);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,10,_ctx) ) {
			case 1:
				{
				setState(767);
				ddlStatement();
				}
				break;
			case 2:
				{
				setState(768);
				dmlStatement();
				}
				break;
			case 3:
				{
				setState(769);
				transactionStatement();
				}
				break;
			case 4:
				{
				setState(770);
				replicationStatement();
				}
				break;
			case 5:
				{
				setState(771);
				preparedStatement();
				}
				break;
			case 6:
				{
				setState(772);
				administrationStatement();
				}
				break;
			case 7:
				{
				setState(773);
				utilityStatement();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class SetStatementForContext extends ParserRuleContext {
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode STATEMENT() { return getToken(MariaDBParser.STATEMENT, 0); }
		public List ID() { return getTokens(MariaDBParser.ID); }
		public TerminalNode ID(int i) {
			return getToken(MariaDBParser.ID, i);
		}
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.EQUAL_SYMBOL, i);
		}
		public List constant() {
			return getRuleContexts(ConstantContext.class);
		}
		public ConstantContext constant(int i) {
			return getRuleContext(ConstantContext.class,i);
		}
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public SetStatementForContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_setStatementFor; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetStatementFor(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetStatementFor(this);
		}
	}

	public final SetStatementForContext setStatementFor() throws RecognitionException {
		SetStatementForContext _localctx = new SetStatementForContext(_ctx, getState());
		enterRule(_localctx, 6, RULE_setStatementFor);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(776);
			match(SET);
			setState(777);
			match(STATEMENT);
			setState(778);
			match(ID);
			setState(779);
			match(EQUAL_SYMBOL);
			setState(780);
			constant();
			setState(787);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(781);
				match(COMMA);
				setState(782);
				match(ID);
				setState(783);
				match(EQUAL_SYMBOL);
				setState(784);
				constant();
				}
				}
				setState(789);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(790);
			match(FOR);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class EmptyStatement_Context extends ParserRuleContext {
		public TerminalNode SEMI() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterEmptyStatement_(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitEmptyStatement_(this);
		}
	}

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

	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 CreateSequenceContext createSequence() {
			return getRuleContext(CreateSequenceContext.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 AlterSequenceContext alterSequence() {
			return getRuleContext(AlterSequenceContext.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 DropSequenceContext dropSequence() {
			return getRuleContext(DropSequenceContext.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDdlStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDdlStatement(this);
		}
	}

	public final DdlStatementContext ddlStatement() throws RecognitionException {
		DdlStatementContext _localctx = new DdlStatementContext(_ctx, getState());
		enterRule(_localctx, 10, RULE_ddlStatement);
		try {
			setState(835);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,12,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(794);
				createDatabase();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(795);
				createEvent();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(796);
				createIndex();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(797);
				createLogfileGroup();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(798);
				createProcedure();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(799);
				createFunction();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(800);
				createServer();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(801);
				createTable();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(802);
				createTablespaceInnodb();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(803);
				createTablespaceNdb();
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(804);
				createTrigger();
				}
				break;
			case 12:
				enterOuterAlt(_localctx, 12);
				{
				setState(805);
				createView();
				}
				break;
			case 13:
				enterOuterAlt(_localctx, 13);
				{
				setState(806);
				createRole();
				}
				break;
			case 14:
				enterOuterAlt(_localctx, 14);
				{
				setState(807);
				createSequence();
				}
				break;
			case 15:
				enterOuterAlt(_localctx, 15);
				{
				setState(808);
				alterDatabase();
				}
				break;
			case 16:
				enterOuterAlt(_localctx, 16);
				{
				setState(809);
				alterEvent();
				}
				break;
			case 17:
				enterOuterAlt(_localctx, 17);
				{
				setState(810);
				alterFunction();
				}
				break;
			case 18:
				enterOuterAlt(_localctx, 18);
				{
				setState(811);
				alterInstance();
				}
				break;
			case 19:
				enterOuterAlt(_localctx, 19);
				{
				setState(812);
				alterLogfileGroup();
				}
				break;
			case 20:
				enterOuterAlt(_localctx, 20);
				{
				setState(813);
				alterProcedure();
				}
				break;
			case 21:
				enterOuterAlt(_localctx, 21);
				{
				setState(814);
				alterServer();
				}
				break;
			case 22:
				enterOuterAlt(_localctx, 22);
				{
				setState(815);
				alterTable();
				}
				break;
			case 23:
				enterOuterAlt(_localctx, 23);
				{
				setState(816);
				alterTablespace();
				}
				break;
			case 24:
				enterOuterAlt(_localctx, 24);
				{
				setState(817);
				alterView();
				}
				break;
			case 25:
				enterOuterAlt(_localctx, 25);
				{
				setState(818);
				alterSequence();
				}
				break;
			case 26:
				enterOuterAlt(_localctx, 26);
				{
				setState(819);
				dropDatabase();
				}
				break;
			case 27:
				enterOuterAlt(_localctx, 27);
				{
				setState(820);
				dropEvent();
				}
				break;
			case 28:
				enterOuterAlt(_localctx, 28);
				{
				setState(821);
				dropIndex();
				}
				break;
			case 29:
				enterOuterAlt(_localctx, 29);
				{
				setState(822);
				dropLogfileGroup();
				}
				break;
			case 30:
				enterOuterAlt(_localctx, 30);
				{
				setState(823);
				dropProcedure();
				}
				break;
			case 31:
				enterOuterAlt(_localctx, 31);
				{
				setState(824);
				dropFunction();
				}
				break;
			case 32:
				enterOuterAlt(_localctx, 32);
				{
				setState(825);
				dropServer();
				}
				break;
			case 33:
				enterOuterAlt(_localctx, 33);
				{
				setState(826);
				dropTable();
				}
				break;
			case 34:
				enterOuterAlt(_localctx, 34);
				{
				setState(827);
				dropTablespace();
				}
				break;
			case 35:
				enterOuterAlt(_localctx, 35);
				{
				setState(828);
				dropTrigger();
				}
				break;
			case 36:
				enterOuterAlt(_localctx, 36);
				{
				setState(829);
				dropView();
				}
				break;
			case 37:
				enterOuterAlt(_localctx, 37);
				{
				setState(830);
				dropRole();
				}
				break;
			case 38:
				enterOuterAlt(_localctx, 38);
				{
				setState(831);
				dropSequence();
				}
				break;
			case 39:
				enterOuterAlt(_localctx, 39);
				{
				setState(832);
				setRole();
				}
				break;
			case 40:
				enterOuterAlt(_localctx, 40);
				{
				setState(833);
				renameTable();
				}
				break;
			case 41:
				enterOuterAlt(_localctx, 41);
				{
				setState(834);
				truncateTable();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 DmlStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dmlStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterDmlStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDmlStatement(this);
		}
	}

	public final DmlStatementContext dmlStatement() throws RecognitionException {
		DmlStatementContext _localctx = new DmlStatementContext(_ctx, getState());
		enterRule(_localctx, 12, RULE_dmlStatement);
		try {
			setState(848);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,13,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(837);
				selectStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(838);
				insertStatement();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(839);
				updateStatement();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(840);
				deleteStatement();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(841);
				replaceStatement();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(842);
				callStatement();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(843);
				loadDataStatement();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(844);
				loadXmlStatement();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(845);
				doStatement();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(846);
				handlerStatement();
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(847);
				valuesStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTransactionStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTransactionStatement(this);
		}
	}

	public final TransactionStatementContext transactionStatement() throws RecognitionException {
		TransactionStatementContext _localctx = new TransactionStatementContext(_ctx, getState());
		enterRule(_localctx, 14, RULE_transactionStatement);
		try {
			setState(859);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,14,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(850);
				startTransaction();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(851);
				beginWork();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(852);
				commitWork();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(853);
				rollbackWork();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(854);
				savepointStatement();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(855);
				rollbackStatement();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(856);
				releaseStatement();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(857);
				lockTables();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(858);
				unlockTables();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterReplicationStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitReplicationStatement(this);
		}
	}

	public final ReplicationStatementContext replicationStatement() throws RecognitionException {
		ReplicationStatementContext _localctx = new ReplicationStatementContext(_ctx, getState());
		enterRule(_localctx, 16, RULE_replicationStatement);
		try {
			setState(876);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,15,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(861);
				changeMaster();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(862);
				changeReplicationFilter();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(863);
				purgeBinaryLogs();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(864);
				resetMaster();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(865);
				resetSlave();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(866);
				startSlave();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(867);
				stopSlave();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(868);
				startGroupReplication();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(869);
				stopGroupReplication();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(870);
				xaStartTransaction();
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(871);
				xaEndTransaction();
				}
				break;
			case 12:
				enterOuterAlt(_localctx, 12);
				{
				setState(872);
				xaPrepareStatement();
				}
				break;
			case 13:
				enterOuterAlt(_localctx, 13);
				{
				setState(873);
				xaCommitWork();
				}
				break;
			case 14:
				enterOuterAlt(_localctx, 14);
				{
				setState(874);
				xaRollbackWork();
				}
				break;
			case 15:
				enterOuterAlt(_localctx, 15);
				{
				setState(875);
				xaRecoverWork();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPreparedStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPreparedStatement(this);
		}
	}

	public final PreparedStatementContext preparedStatement() throws RecognitionException {
		PreparedStatementContext _localctx = new PreparedStatementContext(_ctx, getState());
		enterRule(_localctx, 18, RULE_preparedStatement);
		try {
			setState(881);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case PREPARE:
				enterOuterAlt(_localctx, 1);
				{
				setState(878);
				prepareStatement();
				}
				break;
			case EXECUTE:
				enterOuterAlt(_localctx, 2);
				{
				setState(879);
				executeStatement();
				}
				break;
			case DROP:
			case DEALLOCATE:
				enterOuterAlt(_localctx, 3);
				{
				setState(880);
				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;
	}

	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 WithClauseContext withClause() {
			return getRuleContext(WithClauseContext.class,0);
		}
		public DmlStatementContext dmlStatement() {
			return getRuleContext(DmlStatementContext.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCompoundStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCompoundStatement(this);
		}
	}

	public final CompoundStatementContext compoundStatement() throws RecognitionException {
		CompoundStatementContext _localctx = new CompoundStatementContext(_ctx, getState());
		enterRule(_localctx, 20, RULE_compoundStatement);
		try {
			setState(896);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,17,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(883);
				blockStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(884);
				caseStatement();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(885);
				ifStatement();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(886);
				leaveStatement();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(887);
				loopStatement();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(888);
				repeatStatement();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(889);
				whileStatement();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(890);
				iterateStatement();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(891);
				returnStatement();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(892);
				cursorStatement();
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(893);
				withClause();
				setState(894);
				dmlStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 ExplainStatementContext explainStatement() {
			return getRuleContext(ExplainStatementContext.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAdministrationStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAdministrationStatement(this);
		}
	}

	public final AdministrationStatementContext administrationStatement() throws RecognitionException {
		AdministrationStatementContext _localctx = new AdministrationStatementContext(_ctx, getState());
		enterRule(_localctx, 22, RULE_administrationStatement);
		try {
			setState(924);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,18,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(898);
				alterUser();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(899);
				createUser();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(900);
				dropUser();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(901);
				grantStatement();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(902);
				grantProxy();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(903);
				renameUser();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(904);
				revokeStatement();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(905);
				revokeProxy();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(906);
				analyzeTable();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(907);
				checkTable();
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(908);
				checksumTable();
				}
				break;
			case 12:
				enterOuterAlt(_localctx, 12);
				{
				setState(909);
				optimizeTable();
				}
				break;
			case 13:
				enterOuterAlt(_localctx, 13);
				{
				setState(910);
				repairTable();
				}
				break;
			case 14:
				enterOuterAlt(_localctx, 14);
				{
				setState(911);
				createUdfunction();
				}
				break;
			case 15:
				enterOuterAlt(_localctx, 15);
				{
				setState(912);
				installPlugin();
				}
				break;
			case 16:
				enterOuterAlt(_localctx, 16);
				{
				setState(913);
				uninstallPlugin();
				}
				break;
			case 17:
				enterOuterAlt(_localctx, 17);
				{
				setState(914);
				setStatement();
				}
				break;
			case 18:
				enterOuterAlt(_localctx, 18);
				{
				setState(915);
				showStatement();
				}
				break;
			case 19:
				enterOuterAlt(_localctx, 19);
				{
				setState(916);
				binlogStatement();
				}
				break;
			case 20:
				enterOuterAlt(_localctx, 20);
				{
				setState(917);
				cacheIndexStatement();
				}
				break;
			case 21:
				enterOuterAlt(_localctx, 21);
				{
				setState(918);
				flushStatement();
				}
				break;
			case 22:
				enterOuterAlt(_localctx, 22);
				{
				setState(919);
				killStatement();
				}
				break;
			case 23:
				enterOuterAlt(_localctx, 23);
				{
				setState(920);
				loadIndexIntoCache();
				}
				break;
			case 24:
				enterOuterAlt(_localctx, 24);
				{
				setState(921);
				resetStatement();
				}
				break;
			case 25:
				enterOuterAlt(_localctx, 25);
				{
				setState(922);
				shutdownStatement();
				}
				break;
			case 26:
				enterOuterAlt(_localctx, 26);
				{
				setState(923);
				explainStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUtilityStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUtilityStatement(this);
		}
	}

	public final UtilityStatementContext utilityStatement() throws RecognitionException {
		UtilityStatementContext _localctx = new UtilityStatementContext(_ctx, getState());
		enterRule(_localctx, 24, RULE_utilityStatement);
		try {
			setState(933);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,19,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(926);
				simpleDescribeStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(927);
				fullDescribeStatement();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(928);
				helpStatement();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(929);
				useStatement();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(930);
				signalStatement();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(931);
				resignalStatement();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(932);
				diagnosticsStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CreateDatabaseContext extends ParserRuleContext {
		public Token dbFormat;
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DATABASE() { return getToken(MariaDBParser.DATABASE, 0); }
		public TerminalNode SCHEMA() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateDatabase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateDatabase(this);
		}
	}

	public final CreateDatabaseContext createDatabase() throws RecognitionException {
		CreateDatabaseContext _localctx = new CreateDatabaseContext(_ctx, getState());
		enterRule(_localctx, 26, RULE_createDatabase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(935);
			match(CREATE);
			setState(936);
			((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(938);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,20,_ctx) ) {
			case 1:
				{
				setState(937);
				ifNotExists();
				}
				break;
			}
			setState(940);
			uid();
			setState(944);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while ((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << CHARACTER) | (1L << COLLATE) | (1L << DEFAULT))) != 0) || _la==READ || _la==CHAR || _la==ENCRYPTION || _la==CHARSET) {
				{
				{
				setState(941);
				createDatabaseOption();
				}
				}
				setState(946);
				_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;
	}

	public static class CreateEventContext extends ParserRuleContext {
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode EVENT() { return getToken(MariaDBParser.EVENT, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public List ON() { return getTokens(MariaDBParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MariaDBParser.ON, i);
		}
		public TerminalNode SCHEDULE() { return getToken(MariaDBParser.SCHEDULE, 0); }
		public ScheduleExpressionContext scheduleExpression() {
			return getRuleContext(ScheduleExpressionContext.class,0);
		}
		public TerminalNode DO() { return getToken(MariaDBParser.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(MariaDBParser.COMPLETION, 0); }
		public TerminalNode PRESERVE() { return getToken(MariaDBParser.PRESERVE, 0); }
		public EnableTypeContext enableType() {
			return getRuleContext(EnableTypeContext.class,0);
		}
		public TerminalNode COMMENT() { return getToken(MariaDBParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateEvent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateEvent(this);
		}
	}

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

			setState(951);
			match(EVENT);
			setState(953);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,23,_ctx) ) {
			case 1:
				{
				setState(952);
				ifNotExists();
				}
				break;
			}
			setState(955);
			fullId();
			setState(956);
			match(ON);
			setState(957);
			match(SCHEDULE);
			setState(958);
			scheduleExpression();
			setState(965);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ON) {
				{
				setState(959);
				match(ON);
				setState(960);
				match(COMPLETION);
				setState(962);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(961);
					match(NOT);
					}
				}

				setState(964);
				match(PRESERVE);
				}
			}

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

			setState(972);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMENT) {
				{
				setState(970);
				match(COMMENT);
				setState(971);
				match(STRING_LITERAL);
				}
			}

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

	public static class CreateIndexContext extends ParserRuleContext {
		public Token intimeAction;
		public Token indexCategory;
		public Token algType;
		public Token lockType;
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.class,0);
		}
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public IndexTypeContext indexType() {
			return getRuleContext(IndexTypeContext.class,0);
		}
		public WaitNowaitClauseContext waitNowaitClause() {
			return getRuleContext(WaitNowaitClauseContext.class,0);
		}
		public List indexOption() {
			return getRuleContexts(IndexOptionContext.class);
		}
		public IndexOptionContext indexOption(int i) {
			return getRuleContext(IndexOptionContext.class,i);
		}
		public List ALGORITHM() { return getTokens(MariaDBParser.ALGORITHM); }
		public TerminalNode ALGORITHM(int i) {
			return getToken(MariaDBParser.ALGORITHM, i);
		}
		public List LOCK() { return getTokens(MariaDBParser.LOCK); }
		public TerminalNode LOCK(int i) {
			return getToken(MariaDBParser.LOCK, i);
		}
		public TerminalNode ONLINE() { return getToken(MariaDBParser.ONLINE, 0); }
		public TerminalNode OFFLINE() { return getToken(MariaDBParser.OFFLINE, 0); }
		public TerminalNode UNIQUE() { return getToken(MariaDBParser.UNIQUE, 0); }
		public TerminalNode FULLTEXT() { return getToken(MariaDBParser.FULLTEXT, 0); }
		public TerminalNode SPATIAL() { return getToken(MariaDBParser.SPATIAL, 0); }
		public List DEFAULT() { return getTokens(MariaDBParser.DEFAULT); }
		public TerminalNode DEFAULT(int i) {
			return getToken(MariaDBParser.DEFAULT, i);
		}
		public List INPLACE() { return getTokens(MariaDBParser.INPLACE); }
		public TerminalNode INPLACE(int i) {
			return getToken(MariaDBParser.INPLACE, i);
		}
		public List COPY() { return getTokens(MariaDBParser.COPY); }
		public TerminalNode COPY(int i) {
			return getToken(MariaDBParser.COPY, i);
		}
		public List NOCOPY() { return getTokens(MariaDBParser.NOCOPY); }
		public TerminalNode NOCOPY(int i) {
			return getToken(MariaDBParser.NOCOPY, i);
		}
		public List INSTANT() { return getTokens(MariaDBParser.INSTANT); }
		public TerminalNode INSTANT(int i) {
			return getToken(MariaDBParser.INSTANT, i);
		}
		public List NONE() { return getTokens(MariaDBParser.NONE); }
		public TerminalNode NONE(int i) {
			return getToken(MariaDBParser.NONE, i);
		}
		public List SHARED() { return getTokens(MariaDBParser.SHARED); }
		public TerminalNode SHARED(int i) {
			return getToken(MariaDBParser.SHARED, i);
		}
		public List EXCLUSIVE() { return getTokens(MariaDBParser.EXCLUSIVE); }
		public TerminalNode EXCLUSIVE(int i) {
			return getToken(MariaDBParser.EXCLUSIVE, i);
		}
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateIndex(this);
		}
	}

	public final CreateIndexContext createIndex() throws RecognitionException {
		CreateIndexContext _localctx = new CreateIndexContext(_ctx, getState());
		enterRule(_localctx, 30, RULE_createIndex);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(977);
			match(CREATE);
			setState(979);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OR) {
				{
				setState(978);
				orReplace();
				}
			}

			setState(982);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OFFLINE || _la==ONLINE) {
				{
				setState(981);
				((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(985);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FULLTEXT || _la==SPATIAL || _la==UNIQUE) {
				{
				setState(984);
				((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(987);
			match(INDEX);
			setState(989);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,31,_ctx) ) {
			case 1:
				{
				setState(988);
				ifNotExists();
				}
				break;
			}
			setState(991);
			uid();
			setState(993);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==USING) {
				{
				setState(992);
				indexType();
				}
			}

			setState(995);
			match(ON);
			setState(996);
			tableName();
			setState(997);
			indexColumnNames();
			setState(999);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOWAIT || _la==WAIT) {
				{
				setState(998);
				waitNowaitClause();
				}
			}

			setState(1004);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==IGNORED || _la==NOT || _la==USING || _la==WITH || _la==CLUSTERING || _la==COMMENT || _la==INVISIBLE || _la==KEY_BLOCK_SIZE || _la==VISIBLE || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE) {
				{
				{
				setState(1001);
				indexOption();
				}
				}
				setState(1006);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1019);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,38,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					setState(1017);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case ALGORITHM:
						{
						setState(1007);
						match(ALGORITHM);
						setState(1009);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==EQUAL_SYMBOL) {
							{
							setState(1008);
							match(EQUAL_SYMBOL);
							}
						}

						setState(1011);
						((CreateIndexContext)_localctx).algType = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==DEFAULT || _la==COPY || _la==INPLACE || _la==INSTANT || _la==NOCOPY) ) {
							((CreateIndexContext)_localctx).algType = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						break;
					case LOCK:
						{
						setState(1012);
						match(LOCK);
						setState(1014);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==EQUAL_SYMBOL) {
							{
							setState(1013);
							match(EQUAL_SYMBOL);
							}
						}

						setState(1016);
						((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(1021);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,38,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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(MariaDBParser.CREATE, 0); }
		public TerminalNode LOGFILE() { return getToken(MariaDBParser.LOGFILE, 0); }
		public TerminalNode GROUP() { return getToken(MariaDBParser.GROUP, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode UNDOFILE() { return getToken(MariaDBParser.UNDOFILE, 0); }
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public List STRING_LITERAL() { return getTokens(MariaDBParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MariaDBParser.STRING_LITERAL, i);
		}
		public TerminalNode INITIAL_SIZE() { return getToken(MariaDBParser.INITIAL_SIZE, 0); }
		public TerminalNode UNDO_BUFFER_SIZE() { return getToken(MariaDBParser.UNDO_BUFFER_SIZE, 0); }
		public TerminalNode REDO_BUFFER_SIZE() { return getToken(MariaDBParser.REDO_BUFFER_SIZE, 0); }
		public TerminalNode NODEGROUP() { return getToken(MariaDBParser.NODEGROUP, 0); }
		public TerminalNode WAIT() { return getToken(MariaDBParser.WAIT, 0); }
		public TerminalNode COMMENT() { return getToken(MariaDBParser.COMMENT, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateLogfileGroup(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateLogfileGroup(this);
		}
	}

	public final CreateLogfileGroupContext createLogfileGroup() throws RecognitionException {
		CreateLogfileGroupContext _localctx = new CreateLogfileGroupContext(_ctx, getState());
		enterRule(_localctx, 32, RULE_createLogfileGroup);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1022);
			match(CREATE);
			setState(1023);
			match(LOGFILE);
			setState(1024);
			match(GROUP);
			setState(1025);
			uid();
			setState(1026);
			match(ADD);
			setState(1027);
			match(UNDOFILE);
			setState(1028);
			((CreateLogfileGroupContext)_localctx).undoFile = match(STRING_LITERAL);
			setState(1034);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INITIAL_SIZE) {
				{
				setState(1029);
				match(INITIAL_SIZE);
				setState(1031);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1030);
					match(EQUAL_SYMBOL);
					}
				}

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

			setState(1041);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==UNDO_BUFFER_SIZE) {
				{
				setState(1036);
				match(UNDO_BUFFER_SIZE);
				setState(1038);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1037);
					match(EQUAL_SYMBOL);
					}
				}

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

			setState(1048);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==REDO_BUFFER_SIZE) {
				{
				setState(1043);
				match(REDO_BUFFER_SIZE);
				setState(1045);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1044);
					match(EQUAL_SYMBOL);
					}
				}

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

			setState(1055);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NODEGROUP) {
				{
				setState(1050);
				match(NODEGROUP);
				setState(1052);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1051);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1054);
				uid();
				}
			}

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

			setState(1065);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMENT) {
				{
				setState(1060);
				match(COMMENT);
				setState(1062);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1061);
					match(EQUAL_SYMBOL);
					}
				}

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

			setState(1067);
			match(ENGINE);
			setState(1069);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EQUAL_SYMBOL) {
				{
				setState(1068);
				match(EQUAL_SYMBOL);
				}
			}

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

	public static class CreateProcedureContext extends ParserRuleContext {
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode PROCEDURE() { return getToken(MariaDBParser.PROCEDURE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public RoutineBodyContext routineBody() {
			return getRuleContext(RoutineBodyContext.class,0);
		}
		public OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateProcedure(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateProcedure(this);
		}
	}

	public final CreateProcedureContext createProcedure() throws RecognitionException {
		CreateProcedureContext _localctx = new CreateProcedureContext(_ctx, getState());
		enterRule(_localctx, 34, RULE_createProcedure);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1073);
			match(CREATE);
			setState(1075);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OR) {
				{
				setState(1074);
				orReplace();
				}
			}

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

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

			setState(1090);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(1086);
				match(COMMA);
				setState(1087);
				procedureParameter();
				}
				}
				setState(1092);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1093);
			match(RR_BRACKET);
			setState(1097);
			_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(1094);
					routineOption();
					}
					} 
				}
				setState(1099);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,55,_ctx);
			}
			setState(1100);
			routineBody();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CreateFunctionContext extends ParserRuleContext {
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode FUNCTION() { return getToken(MariaDBParser.FUNCTION, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode RETURNS() { return getToken(MariaDBParser.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 OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.class,0);
		}
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public TerminalNode AGGREGATE() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateFunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateFunction(this);
		}
	}

	public final CreateFunctionContext createFunction() throws RecognitionException {
		CreateFunctionContext _localctx = new CreateFunctionContext(_ctx, getState());
		enterRule(_localctx, 36, RULE_createFunction);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1102);
			match(CREATE);
			setState(1104);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OR) {
				{
				setState(1103);
				orReplace();
				}
			}

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

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

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

			setState(1125);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(1121);
				match(COMMA);
				setState(1122);
				functionParameter();
				}
				}
				setState(1127);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1128);
			match(RR_BRACKET);
			setState(1129);
			match(RETURNS);
			setState(1130);
			dataType();
			setState(1134);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,62,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1131);
					routineOption();
					}
					} 
				}
				setState(1136);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,62,_ctx);
			}
			setState(1139);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ALTER:
			case ANALYZE:
			case ATTRIBUTE:
			case BODY:
			case BUCKETS:
			case CALL:
			case CHANGE:
			case CHECK:
			case CONDITION:
			case CREATE:
			case CURRENT:
			case CURRENT_ROLE:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DELETE:
			case DESC:
			case DESCRIBE:
			case DIAGNOSTICS:
			case DROP:
			case EMPTY:
			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 LOCKED:
			case MAXVALUE:
			case MINVALUE:
			case NUMBER:
			case OPTIMIZE:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case PACKAGE:
			case PURGE:
			case RELEASE:
			case RENAME:
			case REPLACE:
			case RESIGNAL:
			case REVOKE:
			case RIGHT:
			case SCHEMA:
			case SELECT:
			case SET:
			case SHOW:
			case SIGNAL:
			case SKIP_:
			case STACKED:
			case STATEMENT:
			case UNLOCK:
			case UPDATE:
			case USE:
			case VALUES:
			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 CYCLE:
			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 ENCRYPTED:
			case ENCRYPTION:
			case ENCRYPTION_KEY_ID:
			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 INCREMENT:
			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 LOCALES:
			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 NOCACHE:
			case NOCOPY:
			case NOCYCLE:
			case NOMAXVALUE:
			case NOMINVALUE:
			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 QUERY_RESPONSE_TIME:
			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 RESTART:
			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 SEQUENCE:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLAVES:
			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 TYPES:
			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 WSREP_MEMBERSHIP:
			case WSREP_STATUS:
			case X509:
			case XA:
			case XML:
			case YES:
			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 USER_STATISTICS:
			case CLIENT_STATISTICS:
			case INDEX_STATISTICS:
			case TABLE_STATISTICS:
			case ADMIN:
			case AUDIT_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_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_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 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 VIA:
			case LASTVAL:
			case NEXTVAL:
			case SETVAL:
			case PREVIOUS:
			case PERSISTENT:
			case BINLOG_MONITOR:
			case BINLOG_REPLAY:
			case FEDERATED_ADMIN:
			case READ_ONLY_ADMIN:
			case REPLICA:
			case REPLICAS:
			case REPLICATION_MASTER_ADMIN:
			case MONITOR:
			case READ_ONLY:
			case REPLAY:
			case MOD:
			case LR_BRACKET:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				{
				setState(1137);
				routineBody();
				}
				break;
			case RETURN:
				{
				setState(1138);
				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;
	}

	public static class CreateRoleContext extends ParserRuleContext {
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode ROLE() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateRole(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateRole(this);
		}
	}

	public final CreateRoleContext createRole() throws RecognitionException {
		CreateRoleContext _localctx = new CreateRoleContext(_ctx, getState());
		enterRule(_localctx, 38, RULE_createRole);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1141);
			match(CREATE);
			setState(1142);
			match(ROLE);
			setState(1144);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,64,_ctx) ) {
			case 1:
				{
				setState(1143);
				ifNotExists();
				}
				break;
			}
			setState(1146);
			roleName();
			setState(1151);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(1147);
				match(COMMA);
				setState(1148);
				roleName();
				}
				}
				setState(1153);
				_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;
	}

	public static class CreateServerContext extends ParserRuleContext {
		public Token wrapperName;
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode SERVER() { return getToken(MariaDBParser.SERVER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode FOREIGN() { return getToken(MariaDBParser.FOREIGN, 0); }
		public TerminalNode DATA() { return getToken(MariaDBParser.DATA, 0); }
		public TerminalNode WRAPPER() { return getToken(MariaDBParser.WRAPPER, 0); }
		public TerminalNode OPTIONS() { return getToken(MariaDBParser.OPTIONS, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode MYSQL() { return getToken(MariaDBParser.MYSQL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateServer(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateServer(this);
		}
	}

	public final CreateServerContext createServer() throws RecognitionException {
		CreateServerContext _localctx = new CreateServerContext(_ctx, getState());
		enterRule(_localctx, 40, RULE_createServer);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1154);
			match(CREATE);
			setState(1155);
			match(SERVER);
			setState(1156);
			uid();
			setState(1157);
			match(FOREIGN);
			setState(1158);
			match(DATA);
			setState(1159);
			match(WRAPPER);
			setState(1160);
			((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(1161);
			match(OPTIONS);
			setState(1162);
			match(LR_BRACKET);
			setState(1163);
			serverOption();
			setState(1168);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(1164);
				match(COMMA);
				setState(1165);
				serverOption();
				}
				}
				setState(1170);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1171);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class CopyCreateTableContext extends CreateTableContext {
		public TableNameContext parenthesisTable;
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public List tableName() {
			return getRuleContexts(TableNameContext.class);
		}
		public TableNameContext tableName(int i) {
			return getRuleContext(TableNameContext.class,i);
		}
		public TerminalNode LIKE() { return getToken(MariaDBParser.LIKE, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.class,0);
		}
		public TerminalNode TEMPORARY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCopyCreateTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCopyCreateTable(this);
		}
	}
	public static class ColumnCreateTableContext extends CreateTableContext {
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public CreateDefinitionsContext createDefinitions() {
			return getRuleContext(CreateDefinitionsContext.class,0);
		}
		public OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.class,0);
		}
		public TerminalNode TEMPORARY() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public ColumnCreateTableContext(CreateTableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterColumnCreateTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitColumnCreateTable(this);
		}
	}
	public static class QueryCreateTableContext extends CreateTableContext {
		public Token keyViolate;
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.class,0);
		}
		public TerminalNode TEMPORARY() { return getToken(MariaDBParser.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(MariaDBParser.AS, 0); }
		public TerminalNode IGNORE() { return getToken(MariaDBParser.IGNORE, 0); }
		public TerminalNode REPLACE() { return getToken(MariaDBParser.REPLACE, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public QueryCreateTableContext(CreateTableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterQueryCreateTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitQueryCreateTable(this);
		}
	}

	public final CreateTableContext createTable() throws RecognitionException {
		CreateTableContext _localctx = new CreateTableContext(_ctx, getState());
		enterRule(_localctx, 42, RULE_createTable);
		int _la;
		try {
			int _alt;
			setState(1260);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,88,_ctx) ) {
			case 1:
				_localctx = new CopyCreateTableContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1173);
				match(CREATE);
				setState(1175);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==OR) {
					{
					setState(1174);
					orReplace();
					}
				}

				setState(1178);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==TEMPORARY) {
					{
					setState(1177);
					match(TEMPORARY);
					}
				}

				setState(1180);
				match(TABLE);
				setState(1182);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,69,_ctx) ) {
				case 1:
					{
					setState(1181);
					ifNotExists();
					}
					break;
				}
				setState(1184);
				tableName();
				setState(1192);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case LIKE:
					{
					setState(1185);
					match(LIKE);
					setState(1186);
					tableName();
					}
					break;
				case LR_BRACKET:
					{
					setState(1187);
					match(LR_BRACKET);
					setState(1188);
					match(LIKE);
					setState(1189);
					((CopyCreateTableContext)_localctx).parenthesisTable = tableName();
					setState(1190);
					match(RR_BRACKET);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 2:
				_localctx = new QueryCreateTableContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1194);
				match(CREATE);
				setState(1196);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==OR) {
					{
					setState(1195);
					orReplace();
					}
				}

				setState(1199);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==TEMPORARY) {
					{
					setState(1198);
					match(TEMPORARY);
					}
				}

				setState(1201);
				match(TABLE);
				setState(1203);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,73,_ctx) ) {
				case 1:
					{
					setState(1202);
					ifNotExists();
					}
					break;
				}
				setState(1205);
				tableName();
				setState(1207);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,74,_ctx) ) {
				case 1:
					{
					setState(1206);
					createDefinitions();
					}
					break;
				}
				setState(1219);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 26)) & ~0x3f) == 0 && ((1L << (_la - 26)) & ((1L << (CHARACTER - 26)) | (1L << (COLLATE - 26)) | (1L << (DEFAULT - 26)) | (1L << (INDEX - 26)))) != 0) || _la==UNION || _la==CHAR || ((((_la - 341)) & ~0x3f) == 0 && ((1L << (_la - 341)) & ((1L << (AUTOEXTEND_SIZE - 341)) | (1L << (AUTO_INCREMENT - 341)) | (1L << (AVG_ROW_LENGTH - 341)) | (1L << (CHECKSUM - 341)) | (1L << (PAGE_CHECKSUM - 341)) | (1L << (COMMENT - 341)) | (1L << (COMPRESSION - 341)) | (1L << (CONNECTION - 341)) | (1L << (DATA - 341)) | (1L << (DELAY_KEY_WRITE - 341)) | (1L << (ENCRYPTED - 341)))) != 0) || ((((_la - 405)) & ~0x3f) == 0 && ((1L << (_la - 405)) & ((1L << (ENCRYPTION - 405)) | (1L << (ENCRYPTION_KEY_ID - 405)) | (1L << (ENGINE - 405)) | (1L << (INSERT_METHOD - 405)) | (1L << (KEY_BLOCK_SIZE - 405)))) != 0) || ((((_la - 501)) & ~0x3f) == 0 && ((1L << (_la - 501)) & ((1L << (MAX_ROWS - 501)) | (1L << (MIN_ROWS - 501)) | (1L << (PACK_KEYS - 501)) | (1L << (PAGE_COMPRESSED - 501)) | (1L << (PAGE_COMPRESSION_LEVEL - 501)) | (1L << (PASSWORD - 501)))) != 0) || ((((_la - 604)) & ~0x3f) == 0 && ((1L << (_la - 604)) & ((1L << (ROW_FORMAT - 604)) | (1L << (START - 604)) | (1L << (STATS_AUTO_RECALC - 604)) | (1L << (STATS_PERSISTENT - 604)) | (1L << (STATS_SAMPLE_PAGES - 604)) | (1L << (STORAGE - 604)) | (1L << (TABLESPACE - 604)) | (1L << (TABLE_TYPE - 604)) | (1L << (TRANSACTIONAL - 604)))) != 0) || _la==CHARSET || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE || _la==STRING_LITERAL) {
					{
					setState(1209);
					tableOption();
					setState(1216);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (((((_la - 26)) & ~0x3f) == 0 && ((1L << (_la - 26)) & ((1L << (CHARACTER - 26)) | (1L << (COLLATE - 26)) | (1L << (DEFAULT - 26)) | (1L << (INDEX - 26)))) != 0) || _la==UNION || _la==CHAR || ((((_la - 341)) & ~0x3f) == 0 && ((1L << (_la - 341)) & ((1L << (AUTOEXTEND_SIZE - 341)) | (1L << (AUTO_INCREMENT - 341)) | (1L << (AVG_ROW_LENGTH - 341)) | (1L << (CHECKSUM - 341)) | (1L << (PAGE_CHECKSUM - 341)) | (1L << (COMMENT - 341)) | (1L << (COMPRESSION - 341)) | (1L << (CONNECTION - 341)) | (1L << (DATA - 341)) | (1L << (DELAY_KEY_WRITE - 341)) | (1L << (ENCRYPTED - 341)))) != 0) || ((((_la - 405)) & ~0x3f) == 0 && ((1L << (_la - 405)) & ((1L << (ENCRYPTION - 405)) | (1L << (ENCRYPTION_KEY_ID - 405)) | (1L << (ENGINE - 405)) | (1L << (INSERT_METHOD - 405)) | (1L << (KEY_BLOCK_SIZE - 405)))) != 0) || ((((_la - 501)) & ~0x3f) == 0 && ((1L << (_la - 501)) & ((1L << (MAX_ROWS - 501)) | (1L << (MIN_ROWS - 501)) | (1L << (PACK_KEYS - 501)) | (1L << (PAGE_COMPRESSED - 501)) | (1L << (PAGE_COMPRESSION_LEVEL - 501)) | (1L << (PASSWORD - 501)))) != 0) || ((((_la - 604)) & ~0x3f) == 0 && ((1L << (_la - 604)) & ((1L << (ROW_FORMAT - 604)) | (1L << (START - 604)) | (1L << (STATS_AUTO_RECALC - 604)) | (1L << (STATS_PERSISTENT - 604)) | (1L << (STATS_SAMPLE_PAGES - 604)) | (1L << (STORAGE - 604)) | (1L << (TABLESPACE - 604)) | (1L << (TABLE_TYPE - 604)) | (1L << (TRANSACTIONAL - 604)))) != 0) || _la==CHARSET || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE || _la==COMMA || _la==STRING_LITERAL) {
						{
						{
						setState(1211);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==COMMA) {
							{
							setState(1210);
							match(COMMA);
							}
						}

						setState(1213);
						tableOption();
						}
						}
						setState(1218);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

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

				setState(1225);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IGNORE || _la==REPLACE) {
					{
					setState(1224);
					((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(1228);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(1227);
					match(AS);
					}
				}

				setState(1230);
				selectStatement();
				}
				break;
			case 3:
				_localctx = new ColumnCreateTableContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1232);
				match(CREATE);
				setState(1234);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==OR) {
					{
					setState(1233);
					orReplace();
					}
				}

				setState(1237);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==TEMPORARY) {
					{
					setState(1236);
					match(TEMPORARY);
					}
				}

				setState(1239);
				match(TABLE);
				setState(1241);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,83,_ctx) ) {
				case 1:
					{
					setState(1240);
					ifNotExists();
					}
					break;
				}
				setState(1243);
				tableName();
				setState(1244);
				createDefinitions();
				setState(1255);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,86,_ctx) ) {
				case 1:
					{
					setState(1245);
					tableOption();
					setState(1252);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,85,_ctx);
					while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
						if ( _alt==1 ) {
							{
							{
							setState(1247);
							_errHandler.sync(this);
							_la = _input.LA(1);
							if (_la==COMMA) {
								{
								setState(1246);
								match(COMMA);
								}
							}

							setState(1249);
							tableOption();
							}
							} 
						}
						setState(1254);
						_errHandler.sync(this);
						_alt = getInterpreter().adaptivePredict(_input,85,_ctx);
					}
					}
					break;
				}
				setState(1258);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PARTITION) {
					{
					setState(1257);
					partitionDefinitions();
					}
				}

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

	public static class CreateTablespaceInnodbContext extends ParserRuleContext {
		public Token datafile;
		public FileSizeLiteralContext fileBlockSize;
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode DATAFILE() { return getToken(MariaDBParser.DATAFILE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode FILE_BLOCK_SIZE() { return getToken(MariaDBParser.FILE_BLOCK_SIZE, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.EQUAL_SYMBOL, i);
		}
		public TerminalNode ENGINE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateTablespaceInnodb(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateTablespaceInnodb(this);
		}
	}

	public final CreateTablespaceInnodbContext createTablespaceInnodb() throws RecognitionException {
		CreateTablespaceInnodbContext _localctx = new CreateTablespaceInnodbContext(_ctx, getState());
		enterRule(_localctx, 44, RULE_createTablespaceInnodb);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1262);
			match(CREATE);
			setState(1263);
			match(TABLESPACE);
			setState(1264);
			uid();
			setState(1265);
			match(ADD);
			setState(1266);
			match(DATAFILE);
			setState(1267);
			((CreateTablespaceInnodbContext)_localctx).datafile = match(STRING_LITERAL);
			setState(1271);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FILE_BLOCK_SIZE) {
				{
				setState(1268);
				match(FILE_BLOCK_SIZE);
				setState(1269);
				match(EQUAL_SYMBOL);
				setState(1270);
				((CreateTablespaceInnodbContext)_localctx).fileBlockSize = fileSizeLiteral();
				}
			}

			setState(1278);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ENGINE) {
				{
				setState(1273);
				match(ENGINE);
				setState(1275);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1274);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1277);
				engineName();
				}
			}

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

	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(MariaDBParser.CREATE, 0); }
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode DATAFILE() { return getToken(MariaDBParser.DATAFILE, 0); }
		public TerminalNode USE() { return getToken(MariaDBParser.USE, 0); }
		public TerminalNode LOGFILE() { return getToken(MariaDBParser.LOGFILE, 0); }
		public TerminalNode GROUP() { return getToken(MariaDBParser.GROUP, 0); }
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public List STRING_LITERAL() { return getTokens(MariaDBParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MariaDBParser.STRING_LITERAL, i);
		}
		public TerminalNode EXTENT_SIZE() { return getToken(MariaDBParser.EXTENT_SIZE, 0); }
		public TerminalNode INITIAL_SIZE() { return getToken(MariaDBParser.INITIAL_SIZE, 0); }
		public TerminalNode AUTOEXTEND_SIZE() { return getToken(MariaDBParser.AUTOEXTEND_SIZE, 0); }
		public TerminalNode MAX_SIZE() { return getToken(MariaDBParser.MAX_SIZE, 0); }
		public TerminalNode NODEGROUP() { return getToken(MariaDBParser.NODEGROUP, 0); }
		public TerminalNode WAIT() { return getToken(MariaDBParser.WAIT, 0); }
		public TerminalNode COMMENT() { return getToken(MariaDBParser.COMMENT, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateTablespaceNdb(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateTablespaceNdb(this);
		}
	}

	public final CreateTablespaceNdbContext createTablespaceNdb() throws RecognitionException {
		CreateTablespaceNdbContext _localctx = new CreateTablespaceNdbContext(_ctx, getState());
		enterRule(_localctx, 46, RULE_createTablespaceNdb);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1280);
			match(CREATE);
			setState(1281);
			match(TABLESPACE);
			setState(1282);
			uid();
			setState(1283);
			match(ADD);
			setState(1284);
			match(DATAFILE);
			setState(1285);
			((CreateTablespaceNdbContext)_localctx).datafile = match(STRING_LITERAL);
			setState(1286);
			match(USE);
			setState(1287);
			match(LOGFILE);
			setState(1288);
			match(GROUP);
			setState(1289);
			uid();
			setState(1295);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EXTENT_SIZE) {
				{
				setState(1290);
				match(EXTENT_SIZE);
				setState(1292);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1291);
					match(EQUAL_SYMBOL);
					}
				}

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

			setState(1302);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INITIAL_SIZE) {
				{
				setState(1297);
				match(INITIAL_SIZE);
				setState(1299);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1298);
					match(EQUAL_SYMBOL);
					}
				}

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

			setState(1309);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==AUTOEXTEND_SIZE) {
				{
				setState(1304);
				match(AUTOEXTEND_SIZE);
				setState(1306);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1305);
					match(EQUAL_SYMBOL);
					}
				}

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

			setState(1316);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==MAX_SIZE) {
				{
				setState(1311);
				match(MAX_SIZE);
				setState(1313);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1312);
					match(EQUAL_SYMBOL);
					}
				}

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

			setState(1323);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NODEGROUP) {
				{
				setState(1318);
				match(NODEGROUP);
				setState(1320);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1319);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1322);
				uid();
				}
			}

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

			setState(1333);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMENT) {
				{
				setState(1328);
				match(COMMENT);
				setState(1330);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1329);
					match(EQUAL_SYMBOL);
					}
				}

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

			setState(1335);
			match(ENGINE);
			setState(1337);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EQUAL_SYMBOL) {
				{
				setState(1336);
				match(EQUAL_SYMBOL);
				}
			}

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

	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(MariaDBParser.CREATE, 0); }
		public TerminalNode TRIGGER() { return getToken(MariaDBParser.TRIGGER, 0); }
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode EACH() { return getToken(MariaDBParser.EACH, 0); }
		public TerminalNode ROW() { return getToken(MariaDBParser.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(MariaDBParser.BEFORE, 0); }
		public TerminalNode AFTER() { return getToken(MariaDBParser.AFTER, 0); }
		public TerminalNode INSERT() { return getToken(MariaDBParser.INSERT, 0); }
		public TerminalNode UPDATE() { return getToken(MariaDBParser.UPDATE, 0); }
		public TerminalNode DELETE() { return getToken(MariaDBParser.DELETE, 0); }
		public OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.class,0);
		}
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public TerminalNode FOLLOWS() { return getToken(MariaDBParser.FOLLOWS, 0); }
		public TerminalNode PRECEDES() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateTrigger(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateTrigger(this);
		}
	}

	public final CreateTriggerContext createTrigger() throws RecognitionException {
		CreateTriggerContext _localctx = new CreateTriggerContext(_ctx, getState());
		enterRule(_localctx, 48, RULE_createTrigger);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1341);
			match(CREATE);
			setState(1343);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OR) {
				{
				setState(1342);
				orReplace();
				}
			}

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

			setState(1348);
			match(TRIGGER);
			setState(1349);
			((CreateTriggerContext)_localctx).thisTrigger = fullId();
			setState(1350);
			((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(1351);
			((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(1352);
			match(ON);
			setState(1353);
			tableName();
			setState(1354);
			match(FOR);
			setState(1355);
			match(EACH);
			setState(1356);
			match(ROW);
			setState(1359);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,108,_ctx) ) {
			case 1:
				{
				setState(1357);
				((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(1358);
				((CreateTriggerContext)_localctx).otherTrigger = fullId();
				}
				break;
			}
			setState(1361);
			routineBody();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class WithClauseContext extends ParserRuleContext {
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public CommonTableExpressionsContext commonTableExpressions() {
			return getRuleContext(CommonTableExpressionsContext.class,0);
		}
		public TerminalNode RECURSIVE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterWithClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitWithClause(this);
		}
	}

	public final WithClauseContext withClause() throws RecognitionException {
		WithClauseContext _localctx = new WithClauseContext(_ctx, getState());
		enterRule(_localctx, 50, RULE_withClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1363);
			match(WITH);
			setState(1365);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,109,_ctx) ) {
			case 1:
				{
				setState(1364);
				match(RECURSIVE);
				}
				break;
			}
			setState(1367);
			commonTableExpressions();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CommonTableExpressionsContext extends ParserRuleContext {
		public CteNameContext cteName() {
			return getRuleContext(CteNameContext.class,0);
		}
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.LR_BRACKET, i);
		}
		public DmlStatementContext dmlStatement() {
			return getRuleContext(DmlStatementContext.class,0);
		}
		public List RR_BRACKET() { return getTokens(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCommonTableExpressions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCommonTableExpressions(this);
		}
	}

	public final CommonTableExpressionsContext commonTableExpressions() throws RecognitionException {
		CommonTableExpressionsContext _localctx = new CommonTableExpressionsContext(_ctx, getState());
		enterRule(_localctx, 52, RULE_commonTableExpressions);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1369);
			cteName();
			setState(1381);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LR_BRACKET) {
				{
				setState(1370);
				match(LR_BRACKET);
				setState(1371);
				cteColumnName();
				setState(1376);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(1372);
					match(COMMA);
					setState(1373);
					cteColumnName();
					}
					}
					setState(1378);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1379);
				match(RR_BRACKET);
				}
			}

			setState(1383);
			match(AS);
			setState(1384);
			match(LR_BRACKET);
			setState(1385);
			dmlStatement();
			setState(1386);
			match(RR_BRACKET);
			setState(1389);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMA) {
				{
				setState(1387);
				match(COMMA);
				setState(1388);
				commonTableExpressions();
				}
			}

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

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCteName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCteName(this);
		}
	}

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

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCteColumnName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCteColumnName(this);
		}
	}

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

	public static class CreateViewContext extends ParserRuleContext {
		public Token algType;
		public Token secContext;
		public Token checkOption;
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode VIEW() { return getToken(MariaDBParser.VIEW, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.LR_BRACKET, i);
		}
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public List RR_BRACKET() { return getTokens(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.RR_BRACKET, i);
		}
		public OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.class,0);
		}
		public TerminalNode ALGORITHM() { return getToken(MariaDBParser.ALGORITHM, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public TerminalNode SQL() { return getToken(MariaDBParser.SQL, 0); }
		public TerminalNode SECURITY() { return getToken(MariaDBParser.SECURITY, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode UNDEFINED() { return getToken(MariaDBParser.UNDEFINED, 0); }
		public TerminalNode MERGE() { return getToken(MariaDBParser.MERGE, 0); }
		public TerminalNode TEMPTABLE() { return getToken(MariaDBParser.TEMPTABLE, 0); }
		public TerminalNode DEFINER() { return getToken(MariaDBParser.DEFINER, 0); }
		public TerminalNode INVOKER() { return getToken(MariaDBParser.INVOKER, 0); }
		public WithClauseContext withClause() {
			return getRuleContext(WithClauseContext.class,0);
		}
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public TerminalNode CHECK() { return getToken(MariaDBParser.CHECK, 0); }
		public TerminalNode OPTION() { return getToken(MariaDBParser.OPTION, 0); }
		public TerminalNode CASCADED() { return getToken(MariaDBParser.CASCADED, 0); }
		public TerminalNode LOCAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateView(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateView(this);
		}
	}

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

			setState(1402);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ALGORITHM) {
				{
				setState(1399);
				match(ALGORITHM);
				setState(1400);
				match(EQUAL_SYMBOL);
				setState(1401);
				((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(1405);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFINER) {
				{
				setState(1404);
				ownerStatement();
				}
			}

			setState(1410);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==SQL) {
				{
				setState(1407);
				match(SQL);
				setState(1408);
				match(SECURITY);
				setState(1409);
				((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(1412);
			match(VIEW);
			setState(1413);
			fullId();
			setState(1418);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LR_BRACKET) {
				{
				setState(1414);
				match(LR_BRACKET);
				setState(1415);
				uidList();
				setState(1416);
				match(RR_BRACKET);
				}
			}

			setState(1420);
			match(AS);
			setState(1440);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,122,_ctx) ) {
			case 1:
				{
				setState(1421);
				match(LR_BRACKET);
				setState(1423);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH) {
					{
					setState(1422);
					withClause();
					}
				}

				setState(1425);
				selectStatement();
				setState(1426);
				match(RR_BRACKET);
				}
				break;
			case 2:
				{
				setState(1429);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH) {
					{
					setState(1428);
					withClause();
					}
				}

				setState(1431);
				selectStatement();
				setState(1438);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH) {
					{
					setState(1432);
					match(WITH);
					setState(1434);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==CASCADED || _la==LOCAL) {
						{
						setState(1433);
						((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(1436);
					match(CHECK);
					setState(1437);
					match(OPTION);
					}
				}

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

	public static class CreateSequenceContext extends ParserRuleContext {
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode SEQUENCE() { return getToken(MariaDBParser.SEQUENCE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.class,0);
		}
		public TerminalNode TEMPORARY() { return getToken(MariaDBParser.TEMPORARY, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public List sequenceSpec() {
			return getRuleContexts(SequenceSpecContext.class);
		}
		public SequenceSpecContext sequenceSpec(int i) {
			return getRuleContext(SequenceSpecContext.class,i);
		}
		public List tableOption() {
			return getRuleContexts(TableOptionContext.class);
		}
		public TableOptionContext tableOption(int i) {
			return getRuleContext(TableOptionContext.class,i);
		}
		public CreateSequenceContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createSequence; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateSequence(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateSequence(this);
		}
	}

	public final CreateSequenceContext createSequence() throws RecognitionException {
		CreateSequenceContext _localctx = new CreateSequenceContext(_ctx, getState());
		enterRule(_localctx, 60, RULE_createSequence);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1442);
			match(CREATE);
			setState(1444);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OR) {
				{
				setState(1443);
				orReplace();
				}
			}

			setState(1447);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==TEMPORARY) {
				{
				setState(1446);
				match(TEMPORARY);
				}
			}

			setState(1449);
			match(SEQUENCE);
			setState(1451);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,125,_ctx) ) {
			case 1:
				{
				setState(1450);
				ifNotExists();
				}
				break;
			}
			setState(1453);
			fullId();
			setState(1458);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,127,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					setState(1456);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,126,_ctx) ) {
					case 1:
						{
						setState(1454);
						sequenceSpec();
						}
						break;
					case 2:
						{
						setState(1455);
						tableOption();
						}
						break;
					}
					} 
				}
				setState(1460);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,127,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class SequenceSpecContext extends ParserRuleContext {
		public TerminalNode INCREMENT() { return getToken(MariaDBParser.INCREMENT, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode MINVALUE() { return getToken(MariaDBParser.MINVALUE, 0); }
		public TerminalNode NO() { return getToken(MariaDBParser.NO, 0); }
		public TerminalNode NOMINVALUE() { return getToken(MariaDBParser.NOMINVALUE, 0); }
		public TerminalNode MAXVALUE() { return getToken(MariaDBParser.MAXVALUE, 0); }
		public TerminalNode NOMAXVALUE() { return getToken(MariaDBParser.NOMAXVALUE, 0); }
		public TerminalNode START() { return getToken(MariaDBParser.START, 0); }
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public TerminalNode CACHE() { return getToken(MariaDBParser.CACHE, 0); }
		public TerminalNode NOCACHE() { return getToken(MariaDBParser.NOCACHE, 0); }
		public TerminalNode CYCLE() { return getToken(MariaDBParser.CYCLE, 0); }
		public TerminalNode NOCYCLE() { return getToken(MariaDBParser.NOCYCLE, 0); }
		public TerminalNode RESTART() { return getToken(MariaDBParser.RESTART, 0); }
		public SequenceSpecContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_sequenceSpec; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSequenceSpec(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSequenceSpec(this);
		}
	}

	public final SequenceSpecContext sequenceSpec() throws RecognitionException {
		SequenceSpecContext _localctx = new SequenceSpecContext(_ctx, getState());
		enterRule(_localctx, 62, RULE_sequenceSpec);
		int _la;
		try {
			setState(1500);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,134,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1461);
				match(INCREMENT);
				setState(1463);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==BY || _la==EQUAL_SYMBOL) {
					{
					setState(1462);
					_la = _input.LA(1);
					if ( !(_la==BY || _la==EQUAL_SYMBOL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(1465);
				decimalLiteral();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1466);
				match(MINVALUE);
				setState(1468);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1467);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1470);
				decimalLiteral();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(1471);
				match(NO);
				setState(1472);
				match(MINVALUE);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(1473);
				match(NOMINVALUE);
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(1474);
				match(MAXVALUE);
				setState(1476);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1475);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1478);
				decimalLiteral();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(1479);
				match(NO);
				setState(1480);
				match(MAXVALUE);
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(1481);
				match(NOMAXVALUE);
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(1482);
				match(START);
				setState(1484);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH || _la==EQUAL_SYMBOL) {
					{
					setState(1483);
					_la = _input.LA(1);
					if ( !(_la==WITH || _la==EQUAL_SYMBOL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(1486);
				decimalLiteral();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(1487);
				match(CACHE);
				setState(1489);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1488);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1491);
				decimalLiteral();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(1492);
				match(NOCACHE);
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(1493);
				match(CYCLE);
				}
				break;
			case 12:
				enterOuterAlt(_localctx, 12);
				{
				setState(1494);
				match(NOCYCLE);
				}
				break;
			case 13:
				enterOuterAlt(_localctx, 13);
				{
				setState(1495);
				match(RESTART);
				setState(1497);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH || _la==EQUAL_SYMBOL) {
					{
					setState(1496);
					_la = _input.LA(1);
					if ( !(_la==WITH || _la==EQUAL_SYMBOL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

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

	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(MariaDBParser.DEFAULT); }
		public TerminalNode DEFAULT(int i) {
			return getToken(MariaDBParser.DEFAULT, i);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode COLLATE() { return getToken(MariaDBParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public TerminalNode ENCRYPTION() { return getToken(MariaDBParser.ENCRYPTION, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode READ() { return getToken(MariaDBParser.READ, 0); }
		public TerminalNode ONLY() { return getToken(MariaDBParser.ONLY, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateDatabaseOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateDatabaseOption(this);
		}
	}

	public final CreateDatabaseOptionContext createDatabaseOption() throws RecognitionException {
		CreateDatabaseOptionContext _localctx = new CreateDatabaseOptionContext(_ctx, getState());
		enterRule(_localctx, 64, RULE_createDatabaseOption);
		int _la;
		try {
			setState(1535);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,143,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1503);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(1502);
					match(DEFAULT);
					}
				}

				setState(1505);
				charSet();
				setState(1507);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1506);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1511);
				_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(1509);
					charsetName();
					}
					break;
				case DEFAULT:
					{
					setState(1510);
					match(DEFAULT);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1514);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(1513);
					match(DEFAULT);
					}
				}

				setState(1516);
				match(COLLATE);
				setState(1518);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1517);
					match(EQUAL_SYMBOL);
					}
				}

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

				setState(1524);
				match(ENCRYPTION);
				setState(1526);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1525);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1528);
				match(STRING_LITERAL);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(1529);
				match(READ);
				setState(1530);
				match(ONLY);
				setState(1532);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1531);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1534);
				_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;
	}

	public static class CharSetContext extends ParserRuleContext {
		public TerminalNode CHARACTER() { return getToken(MariaDBParser.CHARACTER, 0); }
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode CHARSET() { return getToken(MariaDBParser.CHARSET, 0); }
		public TerminalNode CHAR() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCharSet(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCharSet(this);
		}
	}

	public final CharSetContext charSet() throws RecognitionException {
		CharSetContext _localctx = new CharSetContext(_ctx, getState());
		enterRule(_localctx, 66, RULE_charSet);
		try {
			setState(1542);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CHARACTER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1537);
				match(CHARACTER);
				setState(1538);
				match(SET);
				}
				break;
			case CHARSET:
				enterOuterAlt(_localctx, 2);
				{
				setState(1539);
				match(CHARSET);
				}
				break;
			case CHAR:
				enterOuterAlt(_localctx, 3);
				{
				setState(1540);
				match(CHAR);
				setState(1541);
				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;
	}

	public static class CurrentUserExpressionContext extends ParserRuleContext {
		public TerminalNode CURRENT_USER() { return getToken(MariaDBParser.CURRENT_USER, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCurrentUserExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCurrentUserExpression(this);
		}
	}

	public final CurrentUserExpressionContext currentUserExpression() throws RecognitionException {
		CurrentUserExpressionContext _localctx = new CurrentUserExpressionContext(_ctx, getState());
		enterRule(_localctx, 68, RULE_currentUserExpression);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1544);
			match(CURRENT_USER);
			setState(1547);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,145,_ctx) ) {
			case 1:
				{
				setState(1545);
				match(LR_BRACKET);
				setState(1546);
				match(RR_BRACKET);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class OwnerStatementContext extends ParserRuleContext {
		public TerminalNode DEFINER() { return getToken(MariaDBParser.DEFINER, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public CurrentUserExpressionContext currentUserExpression() {
			return getRuleContext(CurrentUserExpressionContext.class,0);
		}
		public TerminalNode CURRENT_ROLE() { return getToken(MariaDBParser.CURRENT_ROLE, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterOwnerStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitOwnerStatement(this);
		}
	}

	public final OwnerStatementContext ownerStatement() throws RecognitionException {
		OwnerStatementContext _localctx = new OwnerStatementContext(_ctx, getState());
		enterRule(_localctx, 70, RULE_ownerStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1549);
			match(DEFINER);
			setState(1550);
			match(EQUAL_SYMBOL);
			setState(1554);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,146,_ctx) ) {
			case 1:
				{
				setState(1551);
				userName();
				}
				break;
			case 2:
				{
				setState(1552);
				currentUserExpression();
				}
				break;
			case 3:
				{
				setState(1553);
				match(CURRENT_ROLE);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class PreciseScheduleContext extends ScheduleExpressionContext {
		public TerminalNode AT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPreciseSchedule(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPreciseSchedule(this);
		}
	}
	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(MariaDBParser.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(MariaDBParser.STARTS, 0); }
		public TerminalNode ENDS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIntervalSchedule(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIntervalSchedule(this);
		}
	}

	public final ScheduleExpressionContext scheduleExpression() throws RecognitionException {
		ScheduleExpressionContext _localctx = new ScheduleExpressionContext(_ctx, getState());
		enterRule(_localctx, 72, RULE_scheduleExpression);
		int _la;
		try {
			setState(1590);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case AT:
				_localctx = new PreciseScheduleContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1556);
				match(AT);
				setState(1557);
				timestampValue();
				setState(1561);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==PLUS) {
					{
					{
					setState(1558);
					intervalExpr();
					}
					}
					setState(1563);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case EVERY:
				_localctx = new IntervalScheduleContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1564);
				match(EVERY);
				setState(1567);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,148,_ctx) ) {
				case 1:
					{
					setState(1565);
					decimalLiteral();
					}
					break;
				case 2:
					{
					setState(1566);
					expression(0);
					}
					break;
				}
				setState(1569);
				intervalType();
				setState(1578);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STARTS) {
					{
					setState(1570);
					match(STARTS);
					setState(1571);
					((IntervalScheduleContext)_localctx).startTimestamp = timestampValue();
					setState(1575);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==PLUS) {
						{
						{
						setState(1572);
						((IntervalScheduleContext)_localctx).intervalExpr = intervalExpr();
						((IntervalScheduleContext)_localctx).startIntervals.add(((IntervalScheduleContext)_localctx).intervalExpr);
						}
						}
						setState(1577);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				setState(1588);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ENDS) {
					{
					setState(1580);
					match(ENDS);
					setState(1581);
					((IntervalScheduleContext)_localctx).endTimestamp = timestampValue();
					setState(1585);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==PLUS) {
						{
						{
						setState(1582);
						((IntervalScheduleContext)_localctx).intervalExpr = intervalExpr();
						((IntervalScheduleContext)_localctx).endIntervals.add(((IntervalScheduleContext)_localctx).intervalExpr);
						}
						}
						setState(1587);
						_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;
	}

	public static class TimestampValueContext extends ParserRuleContext {
		public TerminalNode CURRENT_TIMESTAMP() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTimestampValue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTimestampValue(this);
		}
	}

	public final TimestampValueContext timestampValue() throws RecognitionException {
		TimestampValueContext _localctx = new TimestampValueContext(_ctx, getState());
		enterRule(_localctx, 74, RULE_timestampValue);
		try {
			setState(1596);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,154,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1592);
				match(CURRENT_TIMESTAMP);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1593);
				stringLiteral();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(1594);
				decimalLiteral();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(1595);
				expression(0);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class IntervalExprContext extends ParserRuleContext {
		public TerminalNode PLUS() { return getToken(MariaDBParser.PLUS, 0); }
		public TerminalNode INTERVAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIntervalExpr(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIntervalExpr(this);
		}
	}

	public final IntervalExprContext intervalExpr() throws RecognitionException {
		IntervalExprContext _localctx = new IntervalExprContext(_ctx, getState());
		enterRule(_localctx, 76, RULE_intervalExpr);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1598);
			match(PLUS);
			setState(1599);
			match(INTERVAL);
			setState(1602);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,155,_ctx) ) {
			case 1:
				{
				setState(1600);
				decimalLiteral();
				}
				break;
			case 2:
				{
				setState(1601);
				expression(0);
				}
				break;
			}
			setState(1604);
			intervalType();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class IntervalTypeContext extends ParserRuleContext {
		public IntervalTypeBaseContext intervalTypeBase() {
			return getRuleContext(IntervalTypeBaseContext.class,0);
		}
		public TerminalNode YEAR() { return getToken(MariaDBParser.YEAR, 0); }
		public TerminalNode YEAR_MONTH() { return getToken(MariaDBParser.YEAR_MONTH, 0); }
		public TerminalNode DAY_HOUR() { return getToken(MariaDBParser.DAY_HOUR, 0); }
		public TerminalNode DAY_MINUTE() { return getToken(MariaDBParser.DAY_MINUTE, 0); }
		public TerminalNode DAY_SECOND() { return getToken(MariaDBParser.DAY_SECOND, 0); }
		public TerminalNode HOUR_MINUTE() { return getToken(MariaDBParser.HOUR_MINUTE, 0); }
		public TerminalNode HOUR_SECOND() { return getToken(MariaDBParser.HOUR_SECOND, 0); }
		public TerminalNode MINUTE_SECOND() { return getToken(MariaDBParser.MINUTE_SECOND, 0); }
		public TerminalNode SECOND_MICROSECOND() { return getToken(MariaDBParser.SECOND_MICROSECOND, 0); }
		public TerminalNode MINUTE_MICROSECOND() { return getToken(MariaDBParser.MINUTE_MICROSECOND, 0); }
		public TerminalNode HOUR_MICROSECOND() { return getToken(MariaDBParser.HOUR_MICROSECOND, 0); }
		public TerminalNode DAY_MICROSECOND() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIntervalType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIntervalType(this);
		}
	}

	public final IntervalTypeContext intervalType() throws RecognitionException {
		IntervalTypeContext _localctx = new IntervalTypeContext(_ctx, getState());
		enterRule(_localctx, 78, RULE_intervalType);
		try {
			setState(1619);
			_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(1606);
				intervalTypeBase();
				}
				break;
			case YEAR:
				enterOuterAlt(_localctx, 2);
				{
				setState(1607);
				match(YEAR);
				}
				break;
			case YEAR_MONTH:
				enterOuterAlt(_localctx, 3);
				{
				setState(1608);
				match(YEAR_MONTH);
				}
				break;
			case DAY_HOUR:
				enterOuterAlt(_localctx, 4);
				{
				setState(1609);
				match(DAY_HOUR);
				}
				break;
			case DAY_MINUTE:
				enterOuterAlt(_localctx, 5);
				{
				setState(1610);
				match(DAY_MINUTE);
				}
				break;
			case DAY_SECOND:
				enterOuterAlt(_localctx, 6);
				{
				setState(1611);
				match(DAY_SECOND);
				}
				break;
			case HOUR_MINUTE:
				enterOuterAlt(_localctx, 7);
				{
				setState(1612);
				match(HOUR_MINUTE);
				}
				break;
			case HOUR_SECOND:
				enterOuterAlt(_localctx, 8);
				{
				setState(1613);
				match(HOUR_SECOND);
				}
				break;
			case MINUTE_SECOND:
				enterOuterAlt(_localctx, 9);
				{
				setState(1614);
				match(MINUTE_SECOND);
				}
				break;
			case SECOND_MICROSECOND:
				enterOuterAlt(_localctx, 10);
				{
				setState(1615);
				match(SECOND_MICROSECOND);
				}
				break;
			case MINUTE_MICROSECOND:
				enterOuterAlt(_localctx, 11);
				{
				setState(1616);
				match(MINUTE_MICROSECOND);
				}
				break;
			case HOUR_MICROSECOND:
				enterOuterAlt(_localctx, 12);
				{
				setState(1617);
				match(HOUR_MICROSECOND);
				}
				break;
			case DAY_MICROSECOND:
				enterOuterAlt(_localctx, 13);
				{
				setState(1618);
				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;
	}

	public static class EnableTypeContext extends ParserRuleContext {
		public TerminalNode ENABLE() { return getToken(MariaDBParser.ENABLE, 0); }
		public TerminalNode DISABLE() { return getToken(MariaDBParser.DISABLE, 0); }
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public TerminalNode SLAVE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterEnableType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitEnableType(this);
		}
	}

	public final EnableTypeContext enableType() throws RecognitionException {
		EnableTypeContext _localctx = new EnableTypeContext(_ctx, getState());
		enterRule(_localctx, 80, RULE_enableType);
		try {
			setState(1626);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,157,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1621);
				match(ENABLE);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1622);
				match(DISABLE);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(1623);
				match(DISABLE);
				setState(1624);
				match(ON);
				setState(1625);
				match(SLAVE);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class IndexTypeContext extends ParserRuleContext {
		public TerminalNode USING() { return getToken(MariaDBParser.USING, 0); }
		public TerminalNode BTREE() { return getToken(MariaDBParser.BTREE, 0); }
		public TerminalNode HASH() { return getToken(MariaDBParser.HASH, 0); }
		public TerminalNode RTREE() { return getToken(MariaDBParser.RTREE, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIndexType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIndexType(this);
		}
	}

	public final IndexTypeContext indexType() throws RecognitionException {
		IndexTypeContext _localctx = new IndexTypeContext(_ctx, getState());
		enterRule(_localctx, 82, RULE_indexType);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1628);
			match(USING);
			setState(1629);
			_la = _input.LA(1);
			if ( !(_la==BTREE || _la==HASH || _la==RTREE) ) {
			_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 static class IndexOptionContext extends ParserRuleContext {
		public TerminalNode KEY_BLOCK_SIZE() { return getToken(MariaDBParser.KEY_BLOCK_SIZE, 0); }
		public FileSizeLiteralContext fileSizeLiteral() {
			return getRuleContext(FileSizeLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public IndexTypeContext indexType() {
			return getRuleContext(IndexTypeContext.class,0);
		}
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public TerminalNode PARSER() { return getToken(MariaDBParser.PARSER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode COMMENT() { return getToken(MariaDBParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode VISIBLE() { return getToken(MariaDBParser.VISIBLE, 0); }
		public TerminalNode INVISIBLE() { return getToken(MariaDBParser.INVISIBLE, 0); }
		public TerminalNode ENGINE_ATTRIBUTE() { return getToken(MariaDBParser.ENGINE_ATTRIBUTE, 0); }
		public TerminalNode SECONDARY_ENGINE_ATTRIBUTE() { return getToken(MariaDBParser.SECONDARY_ENGINE_ATTRIBUTE, 0); }
		public TerminalNode CLUSTERING() { return getToken(MariaDBParser.CLUSTERING, 0); }
		public TerminalNode YES() { return getToken(MariaDBParser.YES, 0); }
		public TerminalNode NO() { return getToken(MariaDBParser.NO, 0); }
		public TerminalNode IGNORED() { return getToken(MariaDBParser.IGNORED, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.NOT, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIndexOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIndexOption(this);
		}
	}

	public final IndexOptionContext indexOption() throws RecognitionException {
		IndexOptionContext _localctx = new IndexOptionContext(_ctx, getState());
		enterRule(_localctx, 84, RULE_indexOption);
		int _la;
		try {
			setState(1661);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case KEY_BLOCK_SIZE:
				enterOuterAlt(_localctx, 1);
				{
				setState(1631);
				match(KEY_BLOCK_SIZE);
				setState(1633);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1632);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1635);
				fileSizeLiteral();
				}
				break;
			case USING:
				enterOuterAlt(_localctx, 2);
				{
				setState(1636);
				indexType();
				}
				break;
			case WITH:
				enterOuterAlt(_localctx, 3);
				{
				setState(1637);
				match(WITH);
				setState(1638);
				match(PARSER);
				setState(1639);
				uid();
				}
				break;
			case COMMENT:
				enterOuterAlt(_localctx, 4);
				{
				setState(1640);
				match(COMMENT);
				setState(1641);
				match(STRING_LITERAL);
				}
				break;
			case INVISIBLE:
			case VISIBLE:
				enterOuterAlt(_localctx, 5);
				{
				setState(1642);
				_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(1643);
				match(ENGINE_ATTRIBUTE);
				setState(1645);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1644);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1647);
				match(STRING_LITERAL);
				}
				break;
			case SECONDARY_ENGINE_ATTRIBUTE:
				enterOuterAlt(_localctx, 7);
				{
				setState(1648);
				match(SECONDARY_ENGINE_ATTRIBUTE);
				setState(1650);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1649);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1652);
				match(STRING_LITERAL);
				}
				break;
			case CLUSTERING:
				enterOuterAlt(_localctx, 8);
				{
				setState(1653);
				match(CLUSTERING);
				setState(1654);
				match(EQUAL_SYMBOL);
				setState(1655);
				_la = _input.LA(1);
				if ( !(_la==NO || _la==YES) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case IGNORED:
			case NOT:
				enterOuterAlt(_localctx, 9);
				{
				setState(1659);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case IGNORED:
					{
					setState(1656);
					match(IGNORED);
					}
					break;
				case NOT:
					{
					setState(1657);
					match(NOT);
					setState(1658);
					match(IGNORED);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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(MariaDBParser.IN, 0); }
		public TerminalNode OUT() { return getToken(MariaDBParser.OUT, 0); }
		public TerminalNode INOUT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterProcedureParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitProcedureParameter(this);
		}
	}

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

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

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFunctionParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFunctionParameter(this);
		}
	}

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

	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);
		}
	}
	public static class RoutineBehaviorContext extends RoutineOptionContext {
		public TerminalNode DETERMINISTIC() { return getToken(MariaDBParser.DETERMINISTIC, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.NOT, 0); }
		public RoutineBehaviorContext(RoutineOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterRoutineBehavior(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRoutineBehavior(this);
		}
	}
	public static class RoutineLanguageContext extends RoutineOptionContext {
		public TerminalNode LANGUAGE() { return getToken(MariaDBParser.LANGUAGE, 0); }
		public TerminalNode SQL() { return getToken(MariaDBParser.SQL, 0); }
		public RoutineLanguageContext(RoutineOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterRoutineLanguage(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRoutineLanguage(this);
		}
	}
	public static class RoutineCommentContext extends RoutineOptionContext {
		public TerminalNode COMMENT() { return getToken(MariaDBParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public RoutineCommentContext(RoutineOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterRoutineComment(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRoutineComment(this);
		}
	}
	public static class RoutineSecurityContext extends RoutineOptionContext {
		public Token context;
		public TerminalNode SQL() { return getToken(MariaDBParser.SQL, 0); }
		public TerminalNode SECURITY() { return getToken(MariaDBParser.SECURITY, 0); }
		public TerminalNode DEFINER() { return getToken(MariaDBParser.DEFINER, 0); }
		public TerminalNode INVOKER() { return getToken(MariaDBParser.INVOKER, 0); }
		public RoutineSecurityContext(RoutineOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterRoutineSecurity(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRoutineSecurity(this);
		}
	}
	public static class RoutineDataContext extends RoutineOptionContext {
		public TerminalNode CONTAINS() { return getToken(MariaDBParser.CONTAINS, 0); }
		public TerminalNode SQL() { return getToken(MariaDBParser.SQL, 0); }
		public TerminalNode NO() { return getToken(MariaDBParser.NO, 0); }
		public TerminalNode READS() { return getToken(MariaDBParser.READS, 0); }
		public TerminalNode DATA() { return getToken(MariaDBParser.DATA, 0); }
		public TerminalNode MODIFIES() { return getToken(MariaDBParser.MODIFIES, 0); }
		public RoutineDataContext(RoutineOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterRoutineData(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRoutineData(this);
		}
	}

	public final RoutineOptionContext routineOption() throws RecognitionException {
		RoutineOptionContext _localctx = new RoutineOptionContext(_ctx, getState());
		enterRule(_localctx, 90, RULE_routineOption);
		int _la;
		try {
			setState(1695);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case COMMENT:
				_localctx = new RoutineCommentContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1672);
				match(COMMENT);
				setState(1673);
				match(STRING_LITERAL);
				}
				break;
			case LANGUAGE:
				_localctx = new RoutineLanguageContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1674);
				match(LANGUAGE);
				setState(1675);
				match(SQL);
				}
				break;
			case DETERMINISTIC:
			case NOT:
				_localctx = new RoutineBehaviorContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1677);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(1676);
					match(NOT);
					}
				}

				setState(1679);
				match(DETERMINISTIC);
				}
				break;
			case MODIFIES:
			case READS:
			case CONTAINS:
			case NO:
				_localctx = new RoutineDataContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1690);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case CONTAINS:
					{
					setState(1680);
					match(CONTAINS);
					setState(1681);
					match(SQL);
					}
					break;
				case NO:
					{
					setState(1682);
					match(NO);
					setState(1683);
					match(SQL);
					}
					break;
				case READS:
					{
					setState(1684);
					match(READS);
					setState(1685);
					match(SQL);
					setState(1686);
					match(DATA);
					}
					break;
				case MODIFIES:
					{
					setState(1687);
					match(MODIFIES);
					setState(1688);
					match(SQL);
					setState(1689);
					match(DATA);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case SQL:
				_localctx = new RoutineSecurityContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1692);
				match(SQL);
				setState(1693);
				match(SECURITY);
				setState(1694);
				((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;
	}

	public static class ServerOptionContext extends ParserRuleContext {
		public TerminalNode HOST() { return getToken(MariaDBParser.HOST, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode DATABASE() { return getToken(MariaDBParser.DATABASE, 0); }
		public TerminalNode USER() { return getToken(MariaDBParser.USER, 0); }
		public TerminalNode PASSWORD() { return getToken(MariaDBParser.PASSWORD, 0); }
		public TerminalNode SOCKET() { return getToken(MariaDBParser.SOCKET, 0); }
		public TerminalNode OWNER() { return getToken(MariaDBParser.OWNER, 0); }
		public TerminalNode PORT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterServerOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitServerOption(this);
		}
	}

	public final ServerOptionContext serverOption() throws RecognitionException {
		ServerOptionContext _localctx = new ServerOptionContext(_ctx, getState());
		enterRule(_localctx, 92, RULE_serverOption);
		try {
			setState(1711);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case HOST:
				enterOuterAlt(_localctx, 1);
				{
				setState(1697);
				match(HOST);
				setState(1698);
				match(STRING_LITERAL);
				}
				break;
			case DATABASE:
				enterOuterAlt(_localctx, 2);
				{
				setState(1699);
				match(DATABASE);
				setState(1700);
				match(STRING_LITERAL);
				}
				break;
			case USER:
				enterOuterAlt(_localctx, 3);
				{
				setState(1701);
				match(USER);
				setState(1702);
				match(STRING_LITERAL);
				}
				break;
			case PASSWORD:
				enterOuterAlt(_localctx, 4);
				{
				setState(1703);
				match(PASSWORD);
				setState(1704);
				match(STRING_LITERAL);
				}
				break;
			case SOCKET:
				enterOuterAlt(_localctx, 5);
				{
				setState(1705);
				match(SOCKET);
				setState(1706);
				match(STRING_LITERAL);
				}
				break;
			case OWNER:
				enterOuterAlt(_localctx, 6);
				{
				setState(1707);
				match(OWNER);
				setState(1708);
				match(STRING_LITERAL);
				}
				break;
			case PORT:
				enterOuterAlt(_localctx, 7);
				{
				setState(1709);
				match(PORT);
				setState(1710);
				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;
	}

	public static class CreateDefinitionsContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateDefinitions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateDefinitions(this);
		}
	}

	public final CreateDefinitionsContext createDefinitions() throws RecognitionException {
		CreateDefinitionsContext _localctx = new CreateDefinitionsContext(_ctx, getState());
		enterRule(_localctx, 94, RULE_createDefinitions);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1713);
			match(LR_BRACKET);
			setState(1714);
			createDefinition();
			setState(1719);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(1715);
				match(COMMA);
				setState(1716);
				createDefinition();
				}
				}
				setState(1721);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1722);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class ColumnDeclarationContext extends CreateDefinitionContext {
		public UidContext uid() {
			return getRuleContext(UidContext.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterColumnDeclaration(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitColumnDeclaration(this);
		}
	}
	public static class ConstraintDeclarationContext extends CreateDefinitionContext {
		public TableConstraintContext tableConstraint() {
			return getRuleContext(TableConstraintContext.class,0);
		}
		public ConstraintDeclarationContext(CreateDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterConstraintDeclaration(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitConstraintDeclaration(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIndexDeclaration(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIndexDeclaration(this);
		}
	}

	public final CreateDefinitionContext createDefinition() throws RecognitionException {
		CreateDefinitionContext _localctx = new CreateDefinitionContext(_ctx, getState());
		enterRule(_localctx, 96, RULE_createDefinition);
		try {
			setState(1729);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,169,_ctx) ) {
			case 1:
				_localctx = new ColumnDeclarationContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1724);
				uid();
				setState(1725);
				columnDefinition();
				}
				break;
			case 2:
				_localctx = new ConstraintDeclarationContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1727);
				tableConstraint();
				}
				break;
			case 3:
				_localctx = new IndexDeclarationContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1728);
				indexColumnDefinition();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 ColumnDefinitionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_columnDefinition; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterColumnDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitColumnDefinition(this);
		}
	}

	public final ColumnDefinitionContext columnDefinition() throws RecognitionException {
		ColumnDefinitionContext _localctx = new ColumnDefinitionContext(_ctx, getState());
		enterRule(_localctx, 98, RULE_columnDefinition);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1731);
			dataType();
			setState(1735);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,170,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1732);
					columnConstraint();
					}
					} 
				}
				setState(1737);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,170,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class StorageColumnConstraintContext extends ColumnConstraintContext {
		public Token storageval;
		public TerminalNode STORAGE() { return getToken(MariaDBParser.STORAGE, 0); }
		public TerminalNode DISK() { return getToken(MariaDBParser.DISK, 0); }
		public TerminalNode MEMORY() { return getToken(MariaDBParser.MEMORY, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public StorageColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterStorageColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStorageColumnConstraint(this);
		}
	}
	public static class VisibilityColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode VISIBLE() { return getToken(MariaDBParser.VISIBLE, 0); }
		public VisibilityColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterVisibilityColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitVisibilityColumnConstraint(this);
		}
	}
	public static class AutoIncrementColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode AUTO_INCREMENT() { return getToken(MariaDBParser.AUTO_INCREMENT, 0); }
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public TerminalNode UPDATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAutoIncrementColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAutoIncrementColumnConstraint(this);
		}
	}
	public static class CommentColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode COMMENT() { return getToken(MariaDBParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public CommentColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterCommentColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCommentColumnConstraint(this);
		}
	}
	public static class UniqueKeyColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode UNIQUE() { return getToken(MariaDBParser.UNIQUE, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public UniqueKeyColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterUniqueKeyColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUniqueKeyColumnConstraint(this);
		}
	}
	public static class SerialDefaultColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode SERIAL() { return getToken(MariaDBParser.SERIAL, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode VALUE() { return getToken(MariaDBParser.VALUE, 0); }
		public SerialDefaultColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSerialDefaultColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSerialDefaultColumnConstraint(this);
		}
	}
	public static class GeneratedColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode GENERATED() { return getToken(MariaDBParser.GENERATED, 0); }
		public TerminalNode ALWAYS() { return getToken(MariaDBParser.ALWAYS, 0); }
		public TerminalNode VIRTUAL() { return getToken(MariaDBParser.VIRTUAL, 0); }
		public TerminalNode STORED() { return getToken(MariaDBParser.STORED, 0); }
		public TerminalNode PERSISTENT() { return getToken(MariaDBParser.PERSISTENT, 0); }
		public GeneratedColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterGeneratedColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitGeneratedColumnConstraint(this);
		}
	}
	public static class FormatColumnConstraintContext extends ColumnConstraintContext {
		public Token colformat;
		public TerminalNode COLUMN_FORMAT() { return getToken(MariaDBParser.COLUMN_FORMAT, 0); }
		public TerminalNode FIXED() { return getToken(MariaDBParser.FIXED, 0); }
		public TerminalNode DYNAMIC() { return getToken(MariaDBParser.DYNAMIC, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public FormatColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterFormatColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFormatColumnConstraint(this);
		}
	}
	public static class CollateColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode COLLATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCollateColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCollateColumnConstraint(this);
		}
	}
	public static class PrimaryKeyColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public TerminalNode PRIMARY() { return getToken(MariaDBParser.PRIMARY, 0); }
		public PrimaryKeyColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPrimaryKeyColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPrimaryKeyColumnConstraint(this);
		}
	}
	public static class CheckColumnConstraintContext extends ColumnConstraintContext {
		public UidContext name;
		public TerminalNode CHECK() { return getToken(MariaDBParser.CHECK, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode CONSTRAINT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCheckColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCheckColumnConstraint(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterNullColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitNullColumnConstraint(this);
		}
	}
	public static class DefaultColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDefaultColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDefaultColumnConstraint(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterReferenceColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitReferenceColumnConstraint(this);
		}
	}
	public static class InvisibilityColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode INVISIBLE() { return getToken(MariaDBParser.INVISIBLE, 0); }
		public InvisibilityColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterInvisibilityColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitInvisibilityColumnConstraint(this);
		}
	}

	public final ColumnConstraintContext columnConstraint() throws RecognitionException {
		ColumnConstraintContext _localctx = new ColumnConstraintContext(_ctx, getState());
		enterRule(_localctx, 100, RULE_columnConstraint);
		int _la;
		try {
			setState(1791);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case NOT:
			case NULL_LITERAL:
			case NULL_SPEC_LITERAL:
				_localctx = new NullColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1738);
				nullNotnull();
				}
				break;
			case DEFAULT:
				_localctx = new DefaultColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1739);
				match(DEFAULT);
				setState(1740);
				defaultValue();
				}
				break;
			case VISIBLE:
				_localctx = new VisibilityColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1741);
				match(VISIBLE);
				}
				break;
			case INVISIBLE:
				_localctx = new InvisibilityColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1742);
				match(INVISIBLE);
				}
				break;
			case ON:
			case AUTO_INCREMENT:
				_localctx = new AutoIncrementColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1747);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case AUTO_INCREMENT:
					{
					setState(1743);
					match(AUTO_INCREMENT);
					}
					break;
				case ON:
					{
					setState(1744);
					match(ON);
					setState(1745);
					match(UPDATE);
					setState(1746);
					currentTimestamp();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case KEY:
			case PRIMARY:
				_localctx = new PrimaryKeyColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(1750);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PRIMARY) {
					{
					setState(1749);
					match(PRIMARY);
					}
				}

				setState(1752);
				match(KEY);
				}
				break;
			case UNIQUE:
				_localctx = new UniqueKeyColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(1753);
				match(UNIQUE);
				setState(1755);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,173,_ctx) ) {
				case 1:
					{
					setState(1754);
					match(KEY);
					}
					break;
				}
				}
				break;
			case COMMENT:
				_localctx = new CommentColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(1757);
				match(COMMENT);
				setState(1758);
				match(STRING_LITERAL);
				}
				break;
			case COLUMN_FORMAT:
				_localctx = new FormatColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(1759);
				match(COLUMN_FORMAT);
				setState(1760);
				((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(1761);
				match(STORAGE);
				setState(1762);
				((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(1763);
				referenceDefinition();
				}
				break;
			case COLLATE:
				_localctx = new CollateColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(1764);
				match(COLLATE);
				setState(1765);
				collationName();
				}
				break;
			case AS:
			case GENERATED:
				_localctx = new GeneratedColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(1768);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==GENERATED) {
					{
					setState(1766);
					match(GENERATED);
					setState(1767);
					match(ALWAYS);
					}
				}

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

					}
				}

				setState(1786);
				match(CHECK);
				setState(1787);
				match(LR_BRACKET);
				setState(1788);
				expression(0);
				setState(1789);
				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;
	}

	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);
		}
	}
	public static class UniqueKeyTableConstraintContext extends TableConstraintContext {
		public UidContext name;
		public Token indexFormat;
		public UidContext index;
		public TerminalNode UNIQUE() { return getToken(MariaDBParser.UNIQUE, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MariaDBParser.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(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public UniqueKeyTableConstraintContext(TableConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterUniqueKeyTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUniqueKeyTableConstraint(this);
		}
	}
	public static class CheckTableConstraintContext extends TableConstraintContext {
		public UidContext name;
		public TerminalNode CHECK() { return getToken(MariaDBParser.CHECK, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode CONSTRAINT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCheckTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCheckTableConstraint(this);
		}
	}
	public static class PrimaryKeyTableConstraintContext extends TableConstraintContext {
		public UidContext name;
		public UidContext index;
		public TerminalNode PRIMARY() { return getToken(MariaDBParser.PRIMARY, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPrimaryKeyTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPrimaryKeyTableConstraint(this);
		}
	}
	public static class ForeignKeyTableConstraintContext extends TableConstraintContext {
		public UidContext name;
		public UidContext index;
		public TerminalNode FOREIGN() { return getToken(MariaDBParser.FOREIGN, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public ReferenceDefinitionContext referenceDefinition() {
			return getRuleContext(ReferenceDefinitionContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterForeignKeyTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitForeignKeyTableConstraint(this);
		}
	}

	public final TableConstraintContext tableConstraint() throws RecognitionException {
		TableConstraintContext _localctx = new TableConstraintContext(_ctx, getState());
		enterRule(_localctx, 102, RULE_tableConstraint);
		int _la;
		try {
			setState(1862);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,195,_ctx) ) {
			case 1:
				_localctx = new PrimaryKeyTableConstraintContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1797);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(1793);
					match(CONSTRAINT);
					setState(1795);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,179,_ctx) ) {
					case 1:
						{
						setState(1794);
						((PrimaryKeyTableConstraintContext)_localctx).name = uid();
						}
						break;
					}
					}
				}

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

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

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

					}
				}

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

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

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

					}
				}

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

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

					}
				}

				setState(1857);
				match(CHECK);
				setState(1858);
				match(LR_BRACKET);
				setState(1859);
				expression(0);
				setState(1860);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ReferenceDefinitionContext extends ParserRuleContext {
		public Token matchType;
		public TerminalNode REFERENCES() { return getToken(MariaDBParser.REFERENCES, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode MATCH() { return getToken(MariaDBParser.MATCH, 0); }
		public ReferenceActionContext referenceAction() {
			return getRuleContext(ReferenceActionContext.class,0);
		}
		public TerminalNode FULL() { return getToken(MariaDBParser.FULL, 0); }
		public TerminalNode PARTIAL() { return getToken(MariaDBParser.PARTIAL, 0); }
		public TerminalNode SIMPLE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterReferenceDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitReferenceDefinition(this);
		}
	}

	public final ReferenceDefinitionContext referenceDefinition() throws RecognitionException {
		ReferenceDefinitionContext _localctx = new ReferenceDefinitionContext(_ctx, getState());
		enterRule(_localctx, 104, RULE_referenceDefinition);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1864);
			match(REFERENCES);
			setState(1865);
			tableName();
			setState(1867);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,196,_ctx) ) {
			case 1:
				{
				setState(1866);
				indexColumnNames();
				}
				break;
			}
			setState(1871);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==MATCH) {
				{
				setState(1869);
				match(MATCH);
				setState(1870);
				((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(1874);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,198,_ctx) ) {
			case 1:
				{
				setState(1873);
				referenceAction();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ReferenceActionContext extends ParserRuleContext {
		public ReferenceControlTypeContext onDelete;
		public ReferenceControlTypeContext onUpdate;
		public List ON() { return getTokens(MariaDBParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MariaDBParser.ON, i);
		}
		public TerminalNode DELETE() { return getToken(MariaDBParser.DELETE, 0); }
		public List referenceControlType() {
			return getRuleContexts(ReferenceControlTypeContext.class);
		}
		public ReferenceControlTypeContext referenceControlType(int i) {
			return getRuleContext(ReferenceControlTypeContext.class,i);
		}
		public TerminalNode UPDATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterReferenceAction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitReferenceAction(this);
		}
	}

	public final ReferenceActionContext referenceAction() throws RecognitionException {
		ReferenceActionContext _localctx = new ReferenceActionContext(_ctx, getState());
		enterRule(_localctx, 106, RULE_referenceAction);
		try {
			setState(1892);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,201,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1876);
				match(ON);
				setState(1877);
				match(DELETE);
				setState(1878);
				((ReferenceActionContext)_localctx).onDelete = referenceControlType();
				setState(1882);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,199,_ctx) ) {
				case 1:
					{
					setState(1879);
					match(ON);
					setState(1880);
					match(UPDATE);
					setState(1881);
					((ReferenceActionContext)_localctx).onUpdate = referenceControlType();
					}
					break;
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1884);
				match(ON);
				setState(1885);
				match(UPDATE);
				setState(1886);
				((ReferenceActionContext)_localctx).onUpdate = referenceControlType();
				setState(1890);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,200,_ctx) ) {
				case 1:
					{
					setState(1887);
					match(ON);
					setState(1888);
					match(DELETE);
					setState(1889);
					((ReferenceActionContext)_localctx).onDelete = referenceControlType();
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ReferenceControlTypeContext extends ParserRuleContext {
		public TerminalNode RESTRICT() { return getToken(MariaDBParser.RESTRICT, 0); }
		public TerminalNode CASCADE() { return getToken(MariaDBParser.CASCADE, 0); }
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode NULL_LITERAL() { return getToken(MariaDBParser.NULL_LITERAL, 0); }
		public TerminalNode NO() { return getToken(MariaDBParser.NO, 0); }
		public TerminalNode ACTION() { return getToken(MariaDBParser.ACTION, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterReferenceControlType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitReferenceControlType(this);
		}
	}

	public final ReferenceControlTypeContext referenceControlType() throws RecognitionException {
		ReferenceControlTypeContext _localctx = new ReferenceControlTypeContext(_ctx, getState());
		enterRule(_localctx, 108, RULE_referenceControlType);
		try {
			setState(1900);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case RESTRICT:
				enterOuterAlt(_localctx, 1);
				{
				setState(1894);
				match(RESTRICT);
				}
				break;
			case CASCADE:
				enterOuterAlt(_localctx, 2);
				{
				setState(1895);
				match(CASCADE);
				}
				break;
			case SET:
				enterOuterAlt(_localctx, 3);
				{
				setState(1896);
				match(SET);
				setState(1897);
				match(NULL_LITERAL);
				}
				break;
			case NO:
				enterOuterAlt(_localctx, 4);
				{
				setState(1898);
				match(NO);
				setState(1899);
				match(ACTION);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class SpecialIndexDeclarationContext extends IndexColumnDefinitionContext {
		public Token indexFormat;
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode FULLTEXT() { return getToken(MariaDBParser.FULLTEXT, 0); }
		public TerminalNode SPATIAL() { return getToken(MariaDBParser.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(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public SpecialIndexDeclarationContext(IndexColumnDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSpecialIndexDeclaration(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSpecialIndexDeclaration(this);
		}
	}
	public static class SimpleIndexDeclarationContext extends IndexColumnDefinitionContext {
		public Token indexFormat;
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSimpleIndexDeclaration(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSimpleIndexDeclaration(this);
		}
	}

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

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

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

				setState(1923);
				indexColumnNames();
				setState(1927);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==IGNORED || _la==NOT || _la==USING || _la==WITH || _la==CLUSTERING || _la==COMMENT || _la==INVISIBLE || _la==KEY_BLOCK_SIZE || _la==VISIBLE || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE) {
					{
					{
					setState(1924);
					indexOption();
					}
					}
					setState(1929);
					_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;
	}

	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);
		}
	}
	public static class TableOptionEngineContext extends TableOptionContext {
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionEngine(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionEngine(this);
		}
	}
	public static class TableOptionMaxRowsContext extends TableOptionContext {
		public TerminalNode MAX_ROWS() { return getToken(MariaDBParser.MAX_ROWS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionMaxRowsContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionMaxRows(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionMaxRows(this);
		}
	}
	public static class TableOptionCollateContext extends TableOptionContext {
		public TerminalNode COLLATE() { return getToken(MariaDBParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionCollateContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionCollate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionCollate(this);
		}
	}
	public static class TableOptionPersistentContext extends TableOptionContext {
		public Token extBoolValue;
		public TerminalNode STATS_PERSISTENT() { return getToken(MariaDBParser.STATS_PERSISTENT, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionPersistentContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionPersistent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionPersistent(this);
		}
	}
	public static class TableOptionTablespaceContext extends TableOptionContext {
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionTablespace(this);
		}
	}
	public static class TableOptionAutoextendSizeContext extends TableOptionContext {
		public TerminalNode AUTOEXTEND_SIZE() { return getToken(MariaDBParser.AUTOEXTEND_SIZE, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionAutoextendSizeContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionAutoextendSize(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionAutoextendSize(this);
		}
	}
	public static class TableOptionPageCompressedContext extends TableOptionContext {
		public TerminalNode PAGE_COMPRESSED() { return getToken(MariaDBParser.PAGE_COMPRESSED, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionPageCompressedContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionPageCompressed(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionPageCompressed(this);
		}
	}
	public static class TableOptionStartTransactionContext extends TableOptionContext {
		public TerminalNode START() { return getToken(MariaDBParser.START, 0); }
		public TerminalNode TRANSACTION() { return getToken(MariaDBParser.TRANSACTION, 0); }
		public TableOptionStartTransactionContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionStartTransaction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionStartTransaction(this);
		}
	}
	public static class TableOptionPackKeysContext extends TableOptionContext {
		public Token extBoolValue;
		public TerminalNode PACK_KEYS() { return getToken(MariaDBParser.PACK_KEYS, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionPackKeysContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionPackKeys(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionPackKeys(this);
		}
	}
	public static class TableOptionPasswordContext extends TableOptionContext {
		public TerminalNode PASSWORD() { return getToken(MariaDBParser.PASSWORD, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionPasswordContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionPassword(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionPassword(this);
		}
	}
	public static class TableOptionUnionContext extends TableOptionContext {
		public TerminalNode UNION() { return getToken(MariaDBParser.UNION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionUnionContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionUnion(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionUnion(this);
		}
	}
	public static class TableOptionSamplePageContext extends TableOptionContext {
		public TerminalNode STATS_SAMPLE_PAGES() { return getToken(MariaDBParser.STATS_SAMPLE_PAGES, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionSamplePageContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionSamplePage(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionSamplePage(this);
		}
	}
	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(MariaDBParser.DEFAULT); }
		public TerminalNode DEFAULT(int i) {
			return getToken(MariaDBParser.DEFAULT, i);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionCharsetContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionCharset(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionCharset(this);
		}
	}
	public static class TableOptionIndexDirectoryContext extends TableOptionContext {
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode DIRECTORY() { return getToken(MariaDBParser.DIRECTORY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionIndexDirectoryContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionIndexDirectory(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionIndexDirectory(this);
		}
	}
	public static class TableOptionTableTypeContext extends TableOptionContext {
		public TerminalNode TABLE_TYPE() { return getToken(MariaDBParser.TABLE_TYPE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionTableType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionTableType(this);
		}
	}
	public static class TableOptionKeyBlockSizeContext extends TableOptionContext {
		public TerminalNode KEY_BLOCK_SIZE() { return getToken(MariaDBParser.KEY_BLOCK_SIZE, 0); }
		public FileSizeLiteralContext fileSizeLiteral() {
			return getRuleContext(FileSizeLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionKeyBlockSizeContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionKeyBlockSize(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionKeyBlockSize(this);
		}
	}
	public static class TableOptionEncryptionContext extends TableOptionContext {
		public TerminalNode ENCRYPTION() { return getToken(MariaDBParser.ENCRYPTION, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionEncryptionContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionEncryption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionEncryption(this);
		}
	}
	public static class TableOptionDataDirectoryContext extends TableOptionContext {
		public TerminalNode DIRECTORY() { return getToken(MariaDBParser.DIRECTORY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode DATA() { return getToken(MariaDBParser.DATA, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionDataDirectoryContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionDataDirectory(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionDataDirectory(this);
		}
	}
	public static class TableOptionRecalculationContext extends TableOptionContext {
		public Token extBoolValue;
		public TerminalNode STATS_AUTO_RECALC() { return getToken(MariaDBParser.STATS_AUTO_RECALC, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionRecalculationContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionRecalculation(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionRecalculation(this);
		}
	}
	public static class TableOptionAutoIncrementContext extends TableOptionContext {
		public TerminalNode AUTO_INCREMENT() { return getToken(MariaDBParser.AUTO_INCREMENT, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionAutoIncrementContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionAutoIncrement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionAutoIncrement(this);
		}
	}
	public static class TableOptionEncryptionKeyIdContext extends TableOptionContext {
		public TerminalNode ENCRYPTION_KEY_ID() { return getToken(MariaDBParser.ENCRYPTION_KEY_ID, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionEncryptionKeyIdContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionEncryptionKeyId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionEncryptionKeyId(this);
		}
	}
	public static class TableOptionChecksumContext extends TableOptionContext {
		public Token boolValue;
		public TerminalNode CHECKSUM() { return getToken(MariaDBParser.CHECKSUM, 0); }
		public TerminalNode PAGE_CHECKSUM() { return getToken(MariaDBParser.PAGE_CHECKSUM, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionChecksumContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionChecksum(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionChecksum(this);
		}
	}
	public static class TableOptionEncryptedContext extends TableOptionContext {
		public EncryptedLiteralContext encryptedLiteral() {
			return getRuleContext(EncryptedLiteralContext.class,0);
		}
		public TerminalNode YES() { return getToken(MariaDBParser.YES, 0); }
		public TerminalNode NO() { return getToken(MariaDBParser.NO, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionEncryptedContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionEncrypted(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionEncrypted(this);
		}
	}
	public static class TableOptionDelayContext extends TableOptionContext {
		public Token boolValue;
		public TerminalNode DELAY_KEY_WRITE() { return getToken(MariaDBParser.DELAY_KEY_WRITE, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionDelayContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionDelay(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionDelay(this);
		}
	}
	public static class TableOptionConnectionContext extends TableOptionContext {
		public TerminalNode CONNECTION() { return getToken(MariaDBParser.CONNECTION, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionConnectionContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionConnection(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionConnection(this);
		}
	}
	public static class TableOptionTransactionalContext extends TableOptionContext {
		public TerminalNode TRANSACTIONAL() { return getToken(MariaDBParser.TRANSACTIONAL, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionTransactionalContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionTransactional(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionTransactional(this);
		}
	}
	public static class TableOptionPageCompressionLevelContext extends TableOptionContext {
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode PAGE_COMPRESSION_LEVEL() { return getToken(MariaDBParser.PAGE_COMPRESSION_LEVEL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionPageCompressionLevelContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionPageCompressionLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionPageCompressionLevel(this);
		}
	}
	public static class TableOptionSecondaryEngineAttributeContext extends TableOptionContext {
		public TerminalNode SECONDARY_ENGINE_ATTRIBUTE() { return getToken(MariaDBParser.SECONDARY_ENGINE_ATTRIBUTE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionSecondaryEngineAttributeContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionSecondaryEngineAttribute(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionSecondaryEngineAttribute(this);
		}
	}
	public static class TableOptionCommentContext extends TableOptionContext {
		public TerminalNode COMMENT() { return getToken(MariaDBParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionCommentContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionComment(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionComment(this);
		}
	}
	public static class TableOptionAverageContext extends TableOptionContext {
		public TerminalNode AVG_ROW_LENGTH() { return getToken(MariaDBParser.AVG_ROW_LENGTH, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionAverageContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionAverage(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionAverage(this);
		}
	}
	public static class TableOptionRowFormatContext extends TableOptionContext {
		public Token rowFormat;
		public TerminalNode ROW_FORMAT() { return getToken(MariaDBParser.ROW_FORMAT, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode DYNAMIC() { return getToken(MariaDBParser.DYNAMIC, 0); }
		public TerminalNode FIXED() { return getToken(MariaDBParser.FIXED, 0); }
		public TerminalNode COMPRESSED() { return getToken(MariaDBParser.COMPRESSED, 0); }
		public TerminalNode REDUNDANT() { return getToken(MariaDBParser.REDUNDANT, 0); }
		public TerminalNode COMPACT() { return getToken(MariaDBParser.COMPACT, 0); }
		public TerminalNode ID() { return getToken(MariaDBParser.ID, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionRowFormatContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionRowFormat(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionRowFormat(this);
		}
	}
	public static class TableOptionCompressionContext extends TableOptionContext {
		public TerminalNode COMPRESSION() { return getToken(MariaDBParser.COMPRESSION, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode ID() { return getToken(MariaDBParser.ID, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionCompressionContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionCompression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionCompression(this);
		}
	}
	public static class TableOptionInsertMethodContext extends TableOptionContext {
		public Token insertMethod;
		public TerminalNode INSERT_METHOD() { return getToken(MariaDBParser.INSERT_METHOD, 0); }
		public TerminalNode NO() { return getToken(MariaDBParser.NO, 0); }
		public TerminalNode FIRST() { return getToken(MariaDBParser.FIRST, 0); }
		public TerminalNode LAST() { return getToken(MariaDBParser.LAST, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionInsertMethodContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionInsertMethod(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionInsertMethod(this);
		}
	}
	public static class TableOptionEngineAttributeContext extends TableOptionContext {
		public TerminalNode ENGINE_ATTRIBUTE() { return getToken(MariaDBParser.ENGINE_ATTRIBUTE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionEngineAttributeContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionEngineAttribute(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionEngineAttribute(this);
		}
	}
	public static class TableOptionMinRowsContext extends TableOptionContext {
		public TerminalNode MIN_ROWS() { return getToken(MariaDBParser.MIN_ROWS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TableOptionMinRowsContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableOptionMinRows(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableOptionMinRows(this);
		}
	}

	public final TableOptionContext tableOption() throws RecognitionException {
		TableOptionContext _localctx = new TableOptionContext(_ctx, getState());
		enterRule(_localctx, 112, RULE_tableOption);
		int _la;
		try {
			setState(2123);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,248,_ctx) ) {
			case 1:
				_localctx = new TableOptionEngineContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1932);
				match(ENGINE);
				setState(1934);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1933);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1937);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,211,_ctx) ) {
				case 1:
					{
					setState(1936);
					engineName();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new TableOptionEngineAttributeContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1939);
				match(ENGINE_ATTRIBUTE);
				setState(1941);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1940);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1943);
				match(STRING_LITERAL);
				}
				break;
			case 3:
				_localctx = new TableOptionAutoextendSizeContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1944);
				match(AUTOEXTEND_SIZE);
				setState(1946);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1945);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1948);
				decimalLiteral();
				}
				break;
			case 4:
				_localctx = new TableOptionAutoIncrementContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1949);
				match(AUTO_INCREMENT);
				setState(1951);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1950);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1953);
				decimalLiteral();
				}
				break;
			case 5:
				_localctx = new TableOptionAverageContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1954);
				match(AVG_ROW_LENGTH);
				setState(1956);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1955);
					match(EQUAL_SYMBOL);
					}
				}

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

				setState(1962);
				charSet();
				setState(1964);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1963);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1968);
				_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(1966);
					charsetName();
					}
					break;
				case DEFAULT:
					{
					setState(1967);
					match(DEFAULT);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 7:
				_localctx = new TableOptionChecksumContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(1970);
				_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(1972);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1971);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1974);
				((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(1976);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(1975);
					match(DEFAULT);
					}
				}

				setState(1978);
				match(COLLATE);
				setState(1980);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1979);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1982);
				collationName();
				}
				break;
			case 9:
				_localctx = new TableOptionCommentContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(1983);
				match(COMMENT);
				setState(1985);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1984);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1987);
				match(STRING_LITERAL);
				}
				break;
			case 10:
				_localctx = new TableOptionCompressionContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(1988);
				match(COMPRESSION);
				setState(1990);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1989);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1992);
				_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(1993);
				match(CONNECTION);
				setState(1995);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1994);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1997);
				match(STRING_LITERAL);
				}
				break;
			case 12:
				_localctx = new TableOptionDataDirectoryContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(1998);
				_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(1999);
				match(DIRECTORY);
				setState(2001);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2000);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2003);
				match(STRING_LITERAL);
				}
				break;
			case 13:
				_localctx = new TableOptionDelayContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(2004);
				match(DELAY_KEY_WRITE);
				setState(2006);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2005);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2008);
				((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(2009);
				match(ENCRYPTION);
				setState(2011);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2010);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2013);
				match(STRING_LITERAL);
				}
				break;
			case 15:
				_localctx = new TableOptionEncryptedContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(2014);
				encryptedLiteral();
				setState(2016);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2015);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2018);
				_la = _input.LA(1);
				if ( !(_la==NO || _la==YES) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 16:
				_localctx = new TableOptionPageCompressedContext(_localctx);
				enterOuterAlt(_localctx, 16);
				{
				setState(2020);
				_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(2022);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2021);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2024);
				_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 17:
				_localctx = new TableOptionPageCompressionLevelContext(_localctx);
				enterOuterAlt(_localctx, 17);
				{
				setState(2025);
				_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(2027);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2026);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2029);
				decimalLiteral();
				}
				break;
			case 18:
				_localctx = new TableOptionEncryptionKeyIdContext(_localctx);
				enterOuterAlt(_localctx, 18);
				{
				setState(2030);
				match(ENCRYPTION_KEY_ID);
				setState(2032);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2031);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2034);
				decimalLiteral();
				}
				break;
			case 19:
				_localctx = new TableOptionIndexDirectoryContext(_localctx);
				enterOuterAlt(_localctx, 19);
				{
				setState(2035);
				match(INDEX);
				setState(2036);
				match(DIRECTORY);
				setState(2038);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2037);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2040);
				match(STRING_LITERAL);
				}
				break;
			case 20:
				_localctx = new TableOptionInsertMethodContext(_localctx);
				enterOuterAlt(_localctx, 20);
				{
				setState(2041);
				match(INSERT_METHOD);
				setState(2043);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2042);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2045);
				((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 21:
				_localctx = new TableOptionKeyBlockSizeContext(_localctx);
				enterOuterAlt(_localctx, 21);
				{
				setState(2046);
				match(KEY_BLOCK_SIZE);
				setState(2048);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2047);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2050);
				fileSizeLiteral();
				}
				break;
			case 22:
				_localctx = new TableOptionMaxRowsContext(_localctx);
				enterOuterAlt(_localctx, 22);
				{
				setState(2051);
				match(MAX_ROWS);
				setState(2053);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2052);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2055);
				decimalLiteral();
				}
				break;
			case 23:
				_localctx = new TableOptionMinRowsContext(_localctx);
				enterOuterAlt(_localctx, 23);
				{
				setState(2056);
				match(MIN_ROWS);
				setState(2058);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2057);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2060);
				decimalLiteral();
				}
				break;
			case 24:
				_localctx = new TableOptionPackKeysContext(_localctx);
				enterOuterAlt(_localctx, 24);
				{
				setState(2061);
				match(PACK_KEYS);
				setState(2063);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2062);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2065);
				((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 25:
				_localctx = new TableOptionPasswordContext(_localctx);
				enterOuterAlt(_localctx, 25);
				{
				setState(2066);
				match(PASSWORD);
				setState(2068);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2067);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2070);
				match(STRING_LITERAL);
				}
				break;
			case 26:
				_localctx = new TableOptionRowFormatContext(_localctx);
				enterOuterAlt(_localctx, 26);
				{
				setState(2071);
				match(ROW_FORMAT);
				setState(2073);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2072);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2075);
				((TableOptionRowFormatContext)_localctx).rowFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFAULT || ((((_la - 370)) & ~0x3f) == 0 && ((1L << (_la - 370)) & ((1L << (COMPACT - 370)) | (1L << (COMPRESSED - 370)) | (1L << (DYNAMIC - 370)) | (1L << (FIXED - 370)))) != 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 27:
				_localctx = new TableOptionStartTransactionContext(_localctx);
				enterOuterAlt(_localctx, 27);
				{
				setState(2076);
				match(START);
				setState(2077);
				match(TRANSACTION);
				}
				break;
			case 28:
				_localctx = new TableOptionSecondaryEngineAttributeContext(_localctx);
				enterOuterAlt(_localctx, 28);
				{
				setState(2078);
				match(SECONDARY_ENGINE_ATTRIBUTE);
				setState(2080);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2079);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2082);
				match(STRING_LITERAL);
				}
				break;
			case 29:
				_localctx = new TableOptionRecalculationContext(_localctx);
				enterOuterAlt(_localctx, 29);
				{
				setState(2083);
				match(STATS_AUTO_RECALC);
				setState(2085);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2084);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2087);
				((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 30:
				_localctx = new TableOptionPersistentContext(_localctx);
				enterOuterAlt(_localctx, 30);
				{
				setState(2088);
				match(STATS_PERSISTENT);
				setState(2090);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2089);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2092);
				((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 31:
				_localctx = new TableOptionSamplePageContext(_localctx);
				enterOuterAlt(_localctx, 31);
				{
				setState(2093);
				match(STATS_SAMPLE_PAGES);
				setState(2095);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2094);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2099);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case DEFAULT:
					{
					setState(2097);
					match(DEFAULT);
					}
					break;
				case ZERO_DECIMAL:
				case ONE_DECIMAL:
				case TWO_DECIMAL:
				case DECIMAL_LITERAL:
				case REAL_LITERAL:
					{
					setState(2098);
					decimalLiteral();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 32:
				_localctx = new TableOptionTablespaceContext(_localctx);
				enterOuterAlt(_localctx, 32);
				{
				setState(2101);
				match(TABLESPACE);
				setState(2102);
				uid();
				setState(2104);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,245,_ctx) ) {
				case 1:
					{
					setState(2103);
					tablespaceStorage();
					}
					break;
				}
				}
				break;
			case 33:
				_localctx = new TableOptionTableTypeContext(_localctx);
				enterOuterAlt(_localctx, 33);
				{
				setState(2106);
				match(TABLE_TYPE);
				setState(2107);
				match(EQUAL_SYMBOL);
				setState(2108);
				tableType();
				}
				break;
			case 34:
				_localctx = new TableOptionTablespaceContext(_localctx);
				enterOuterAlt(_localctx, 34);
				{
				setState(2109);
				tablespaceStorage();
				}
				break;
			case 35:
				_localctx = new TableOptionTransactionalContext(_localctx);
				enterOuterAlt(_localctx, 35);
				{
				setState(2110);
				match(TRANSACTIONAL);
				setState(2112);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2111);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2114);
				_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 36:
				_localctx = new TableOptionUnionContext(_localctx);
				enterOuterAlt(_localctx, 36);
				{
				setState(2115);
				match(UNION);
				setState(2117);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2116);
					match(EQUAL_SYMBOL);
					}
				}

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

	public static class TableTypeContext extends ParserRuleContext {
		public TerminalNode MYSQL() { return getToken(MariaDBParser.MYSQL, 0); }
		public TerminalNode ODBC() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableType(this);
		}
	}

	public final TableTypeContext tableType() throws RecognitionException {
		TableTypeContext _localctx = new TableTypeContext(_ctx, getState());
		enterRule(_localctx, 114, RULE_tableType);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2125);
			_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;
	}

	public static class TablespaceStorageContext extends ParserRuleContext {
		public TerminalNode STORAGE() { return getToken(MariaDBParser.STORAGE, 0); }
		public TerminalNode DISK() { return getToken(MariaDBParser.DISK, 0); }
		public TerminalNode MEMORY() { return getToken(MariaDBParser.MEMORY, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTablespaceStorage(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTablespaceStorage(this);
		}
	}

	public final TablespaceStorageContext tablespaceStorage() throws RecognitionException {
		TablespaceStorageContext _localctx = new TablespaceStorageContext(_ctx, getState());
		enterRule(_localctx, 116, RULE_tablespaceStorage);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2127);
			match(STORAGE);
			setState(2128);
			_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;
	}

	public static class PartitionDefinitionsContext extends ParserRuleContext {
		public DecimalLiteralContext count;
		public DecimalLiteralContext subCount;
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public List BY() { return getTokens(MariaDBParser.BY); }
		public TerminalNode BY(int i) {
			return getToken(MariaDBParser.BY, i);
		}
		public PartitionFunctionDefinitionContext partitionFunctionDefinition() {
			return getRuleContext(PartitionFunctionDefinitionContext.class,0);
		}
		public TerminalNode PARTITIONS() { return getToken(MariaDBParser.PARTITIONS, 0); }
		public TerminalNode SUBPARTITION() { return getToken(MariaDBParser.SUBPARTITION, 0); }
		public SubpartitionFunctionDefinitionContext subpartitionFunctionDefinition() {
			return getRuleContext(SubpartitionFunctionDefinitionContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.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(MariaDBParser.SUBPARTITIONS, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionDefinitions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionDefinitions(this);
		}
	}

	public final PartitionDefinitionsContext partitionDefinitions() throws RecognitionException {
		PartitionDefinitionsContext _localctx = new PartitionDefinitionsContext(_ctx, getState());
		enterRule(_localctx, 118, RULE_partitionDefinitions);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2130);
			match(PARTITION);
			setState(2131);
			match(BY);
			setState(2132);
			partitionFunctionDefinition();
			setState(2135);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITIONS) {
				{
				setState(2133);
				match(PARTITIONS);
				setState(2134);
				((PartitionDefinitionsContext)_localctx).count = decimalLiteral();
				}
			}

			setState(2144);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==SUBPARTITION) {
				{
				setState(2137);
				match(SUBPARTITION);
				setState(2138);
				match(BY);
				setState(2139);
				subpartitionFunctionDefinition();
				setState(2142);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==SUBPARTITIONS) {
					{
					setState(2140);
					match(SUBPARTITIONS);
					setState(2141);
					((PartitionDefinitionsContext)_localctx).subCount = decimalLiteral();
					}
				}

				}
			}

			setState(2157);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,253,_ctx) ) {
			case 1:
				{
				setState(2146);
				match(LR_BRACKET);
				setState(2147);
				partitionDefinition();
				setState(2152);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2148);
					match(COMMA);
					setState(2149);
					partitionDefinition();
					}
					}
					setState(2154);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2155);
				match(RR_BRACKET);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class PartitionFunctionKeyContext extends PartitionFunctionDefinitionContext {
		public Token algType;
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode LINEAR() { return getToken(MariaDBParser.LINEAR, 0); }
		public TerminalNode ALGORITHM() { return getToken(MariaDBParser.ALGORITHM, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public TerminalNode TWO_DECIMAL() { return getToken(MariaDBParser.TWO_DECIMAL, 0); }
		public PartitionFunctionKeyContext(PartitionFunctionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionFunctionKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionFunctionKey(this);
		}
	}
	public static class PartitionFunctionHashContext extends PartitionFunctionDefinitionContext {
		public TerminalNode HASH() { return getToken(MariaDBParser.HASH, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode LINEAR() { return getToken(MariaDBParser.LINEAR, 0); }
		public PartitionFunctionHashContext(PartitionFunctionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionFunctionHash(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionFunctionHash(this);
		}
	}
	public static class PartitionFunctionListContext extends PartitionFunctionDefinitionContext {
		public TerminalNode LIST() { return getToken(MariaDBParser.LIST, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode COLUMNS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionFunctionList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionFunctionList(this);
		}
	}
	public static class PartitionFunctionRangeContext extends PartitionFunctionDefinitionContext {
		public TerminalNode RANGE() { return getToken(MariaDBParser.RANGE, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode COLUMNS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionFunctionRange(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionFunctionRange(this);
		}
	}

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

				setState(2162);
				match(HASH);
				setState(2163);
				match(LR_BRACKET);
				setState(2164);
				expression(0);
				setState(2165);
				match(RR_BRACKET);
				}
				break;
			case 2:
				_localctx = new PartitionFunctionKeyContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2168);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LINEAR) {
					{
					setState(2167);
					match(LINEAR);
					}
				}

				setState(2170);
				match(KEY);
				setState(2174);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ALGORITHM) {
					{
					setState(2171);
					match(ALGORITHM);
					setState(2172);
					match(EQUAL_SYMBOL);
					setState(2173);
					((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(2176);
				match(LR_BRACKET);
				setState(2177);
				uidList();
				setState(2178);
				match(RR_BRACKET);
				}
				break;
			case 3:
				_localctx = new PartitionFunctionRangeContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2180);
				match(RANGE);
				setState(2190);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case LR_BRACKET:
					{
					setState(2181);
					match(LR_BRACKET);
					setState(2182);
					expression(0);
					setState(2183);
					match(RR_BRACKET);
					}
					break;
				case COLUMNS:
					{
					setState(2185);
					match(COLUMNS);
					setState(2186);
					match(LR_BRACKET);
					setState(2187);
					uidList();
					setState(2188);
					match(RR_BRACKET);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 4:
				_localctx = new PartitionFunctionListContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2192);
				match(LIST);
				setState(2202);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case LR_BRACKET:
					{
					setState(2193);
					match(LR_BRACKET);
					setState(2194);
					expression(0);
					setState(2195);
					match(RR_BRACKET);
					}
					break;
				case COLUMNS:
					{
					setState(2197);
					match(COLUMNS);
					setState(2198);
					match(LR_BRACKET);
					setState(2199);
					uidList();
					setState(2200);
					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;
	}

	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);
		}
	}
	public static class SubPartitionFunctionHashContext extends SubpartitionFunctionDefinitionContext {
		public TerminalNode HASH() { return getToken(MariaDBParser.HASH, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode LINEAR() { return getToken(MariaDBParser.LINEAR, 0); }
		public SubPartitionFunctionHashContext(SubpartitionFunctionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSubPartitionFunctionHash(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSubPartitionFunctionHash(this);
		}
	}
	public static class SubPartitionFunctionKeyContext extends SubpartitionFunctionDefinitionContext {
		public Token algType;
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode LINEAR() { return getToken(MariaDBParser.LINEAR, 0); }
		public TerminalNode ALGORITHM() { return getToken(MariaDBParser.ALGORITHM, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public TerminalNode TWO_DECIMAL() { return getToken(MariaDBParser.TWO_DECIMAL, 0); }
		public SubPartitionFunctionKeyContext(SubpartitionFunctionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSubPartitionFunctionKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSubPartitionFunctionKey(this);
		}
	}

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

				setState(2209);
				match(HASH);
				setState(2210);
				match(LR_BRACKET);
				setState(2211);
				expression(0);
				setState(2212);
				match(RR_BRACKET);
				}
				break;
			case 2:
				_localctx = new SubPartitionFunctionKeyContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2215);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LINEAR) {
					{
					setState(2214);
					match(LINEAR);
					}
				}

				setState(2217);
				match(KEY);
				setState(2221);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ALGORITHM) {
					{
					setState(2218);
					match(ALGORITHM);
					setState(2219);
					match(EQUAL_SYMBOL);
					setState(2220);
					((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(2223);
				match(LR_BRACKET);
				setState(2224);
				uidList();
				setState(2225);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class PartitionComparisonContext extends PartitionDefinitionContext {
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode VALUES() { return getToken(MariaDBParser.VALUES, 0); }
		public TerminalNode LESS() { return getToken(MariaDBParser.LESS, 0); }
		public TerminalNode THAN() { return getToken(MariaDBParser.THAN, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.RR_BRACKET, i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionComparison(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionComparison(this);
		}
	}
	public static class PartitionListAtomContext extends PartitionDefinitionContext {
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode VALUES() { return getToken(MariaDBParser.VALUES, 0); }
		public TerminalNode IN() { return getToken(MariaDBParser.IN, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.RR_BRACKET, i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionListAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionListAtom(this);
		}
	}
	public static class PartitionListVectorContext extends PartitionDefinitionContext {
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode VALUES() { return getToken(MariaDBParser.VALUES, 0); }
		public TerminalNode IN() { return getToken(MariaDBParser.IN, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.RR_BRACKET, i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionListVector(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionListVector(this);
		}
	}
	public static class PartitionSimpleContext extends PartitionDefinitionContext {
		public TerminalNode PARTITION() { return getToken(MariaDBParser.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(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public PartitionSimpleContext(PartitionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionSimple(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionSimple(this);
		}
	}

	public final PartitionDefinitionContext partitionDefinition() throws RecognitionException {
		PartitionDefinitionContext _localctx = new PartitionDefinitionContext(_ctx, getState());
		enterRule(_localctx, 124, RULE_partitionDefinition);
		int _la;
		try {
			setState(2375);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,282,_ctx) ) {
			case 1:
				_localctx = new PartitionComparisonContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2229);
				match(PARTITION);
				setState(2230);
				uid();
				setState(2231);
				match(VALUES);
				setState(2232);
				match(LESS);
				setState(2233);
				match(THAN);
				setState(2234);
				match(LR_BRACKET);
				setState(2235);
				partitionDefinerAtom();
				setState(2240);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2236);
					match(COMMA);
					setState(2237);
					partitionDefinerAtom();
					}
					}
					setState(2242);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2243);
				match(RR_BRACKET);
				setState(2247);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & ((1L << (COMMENT - 368)) | (1L << (DATA - 368)) | (1L << (ENGINE - 368)))) != 0) || ((((_la - 501)) & ~0x3f) == 0 && ((1L << (_la - 501)) & ((1L << (MAX_ROWS - 501)) | (1L << (MIN_ROWS - 501)) | (1L << (NODEGROUP - 501)))) != 0) || _la==STORAGE || _la==TABLESPACE) {
					{
					{
					setState(2244);
					partitionOption();
					}
					}
					setState(2249);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2261);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(2250);
					match(LR_BRACKET);
					setState(2251);
					subpartitionDefinition();
					setState(2256);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(2252);
						match(COMMA);
						setState(2253);
						subpartitionDefinition();
						}
						}
						setState(2258);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2259);
					match(RR_BRACKET);
					}
				}

				}
				break;
			case 2:
				_localctx = new PartitionComparisonContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2263);
				match(PARTITION);
				setState(2264);
				uid();
				setState(2265);
				match(VALUES);
				setState(2266);
				match(LESS);
				setState(2267);
				match(THAN);
				setState(2268);
				partitionDefinerAtom();
				setState(2272);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & ((1L << (COMMENT - 368)) | (1L << (DATA - 368)) | (1L << (ENGINE - 368)))) != 0) || ((((_la - 501)) & ~0x3f) == 0 && ((1L << (_la - 501)) & ((1L << (MAX_ROWS - 501)) | (1L << (MIN_ROWS - 501)) | (1L << (NODEGROUP - 501)))) != 0) || _la==STORAGE || _la==TABLESPACE) {
					{
					{
					setState(2269);
					partitionOption();
					}
					}
					setState(2274);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2286);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(2275);
					match(LR_BRACKET);
					setState(2276);
					subpartitionDefinition();
					setState(2281);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(2277);
						match(COMMA);
						setState(2278);
						subpartitionDefinition();
						}
						}
						setState(2283);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2284);
					match(RR_BRACKET);
					}
				}

				}
				break;
			case 3:
				_localctx = new PartitionListAtomContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2288);
				match(PARTITION);
				setState(2289);
				uid();
				setState(2290);
				match(VALUES);
				setState(2291);
				match(IN);
				setState(2292);
				match(LR_BRACKET);
				setState(2293);
				partitionDefinerAtom();
				setState(2298);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2294);
					match(COMMA);
					setState(2295);
					partitionDefinerAtom();
					}
					}
					setState(2300);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2301);
				match(RR_BRACKET);
				setState(2305);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & ((1L << (COMMENT - 368)) | (1L << (DATA - 368)) | (1L << (ENGINE - 368)))) != 0) || ((((_la - 501)) & ~0x3f) == 0 && ((1L << (_la - 501)) & ((1L << (MAX_ROWS - 501)) | (1L << (MIN_ROWS - 501)) | (1L << (NODEGROUP - 501)))) != 0) || _la==STORAGE || _la==TABLESPACE) {
					{
					{
					setState(2302);
					partitionOption();
					}
					}
					setState(2307);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2319);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(2308);
					match(LR_BRACKET);
					setState(2309);
					subpartitionDefinition();
					setState(2314);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(2310);
						match(COMMA);
						setState(2311);
						subpartitionDefinition();
						}
						}
						setState(2316);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2317);
					match(RR_BRACKET);
					}
				}

				}
				break;
			case 4:
				_localctx = new PartitionListVectorContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2321);
				match(PARTITION);
				setState(2322);
				uid();
				setState(2323);
				match(VALUES);
				setState(2324);
				match(IN);
				setState(2325);
				match(LR_BRACKET);
				setState(2326);
				partitionDefinerVector();
				setState(2331);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2327);
					match(COMMA);
					setState(2328);
					partitionDefinerVector();
					}
					}
					setState(2333);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2334);
				match(RR_BRACKET);
				setState(2338);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & ((1L << (COMMENT - 368)) | (1L << (DATA - 368)) | (1L << (ENGINE - 368)))) != 0) || ((((_la - 501)) & ~0x3f) == 0 && ((1L << (_la - 501)) & ((1L << (MAX_ROWS - 501)) | (1L << (MIN_ROWS - 501)) | (1L << (NODEGROUP - 501)))) != 0) || _la==STORAGE || _la==TABLESPACE) {
					{
					{
					setState(2335);
					partitionOption();
					}
					}
					setState(2340);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2352);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(2341);
					match(LR_BRACKET);
					setState(2342);
					subpartitionDefinition();
					setState(2347);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(2343);
						match(COMMA);
						setState(2344);
						subpartitionDefinition();
						}
						}
						setState(2349);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2350);
					match(RR_BRACKET);
					}
				}

				}
				break;
			case 5:
				_localctx = new PartitionSimpleContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2354);
				match(PARTITION);
				setState(2355);
				uid();
				setState(2359);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & ((1L << (COMMENT - 368)) | (1L << (DATA - 368)) | (1L << (ENGINE - 368)))) != 0) || ((((_la - 501)) & ~0x3f) == 0 && ((1L << (_la - 501)) & ((1L << (MAX_ROWS - 501)) | (1L << (MIN_ROWS - 501)) | (1L << (NODEGROUP - 501)))) != 0) || _la==STORAGE || _la==TABLESPACE) {
					{
					{
					setState(2356);
					partitionOption();
					}
					}
					setState(2361);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2373);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(2362);
					match(LR_BRACKET);
					setState(2363);
					subpartitionDefinition();
					setState(2368);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(2364);
						match(COMMA);
						setState(2365);
						subpartitionDefinition();
						}
						}
						setState(2370);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2371);
					match(RR_BRACKET);
					}
				}

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

	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(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionDefinerAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionDefinerAtom(this);
		}
	}

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

	public static class PartitionDefinerVectorContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionDefinerVector(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionDefinerVector(this);
		}
	}

	public final PartitionDefinerVectorContext partitionDefinerVector() throws RecognitionException {
		PartitionDefinerVectorContext _localctx = new PartitionDefinerVectorContext(_ctx, getState());
		enterRule(_localctx, 128, RULE_partitionDefinerVector);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2382);
			match(LR_BRACKET);
			setState(2383);
			partitionDefinerAtom();
			setState(2386); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(2384);
				match(COMMA);
				setState(2385);
				partitionDefinerAtom();
				}
				}
				setState(2388); 
				_errHandler.sync(this);
				_la = _input.LA(1);
			} while ( _la==COMMA );
			setState(2390);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class SubpartitionDefinitionContext extends ParserRuleContext {
		public TerminalNode SUBPARTITION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSubpartitionDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSubpartitionDefinition(this);
		}
	}

	public final SubpartitionDefinitionContext subpartitionDefinition() throws RecognitionException {
		SubpartitionDefinitionContext _localctx = new SubpartitionDefinitionContext(_ctx, getState());
		enterRule(_localctx, 130, RULE_subpartitionDefinition);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2392);
			match(SUBPARTITION);
			setState(2393);
			uid();
			setState(2397);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & ((1L << (COMMENT - 368)) | (1L << (DATA - 368)) | (1L << (ENGINE - 368)))) != 0) || ((((_la - 501)) & ~0x3f) == 0 && ((1L << (_la - 501)) & ((1L << (MAX_ROWS - 501)) | (1L << (MIN_ROWS - 501)) | (1L << (NODEGROUP - 501)))) != 0) || _la==STORAGE || _la==TABLESPACE) {
				{
				{
				setState(2394);
				partitionOption();
				}
				}
				setState(2399);
				_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;
	}

	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);
		}
	}
	public static class PartitionOptionCommentContext extends PartitionOptionContext {
		public Token comment;
		public TerminalNode COMMENT() { return getToken(MariaDBParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionCommentContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionOptionComment(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionOptionComment(this);
		}
	}
	public static class PartitionOptionNodeGroupContext extends PartitionOptionContext {
		public UidContext nodegroup;
		public TerminalNode NODEGROUP() { return getToken(MariaDBParser.NODEGROUP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionNodeGroupContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionOptionNodeGroup(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionOptionNodeGroup(this);
		}
	}
	public static class PartitionOptionIndexDirectoryContext extends PartitionOptionContext {
		public Token indexDirectory;
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode DIRECTORY() { return getToken(MariaDBParser.DIRECTORY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionIndexDirectoryContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionOptionIndexDirectory(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionOptionIndexDirectory(this);
		}
	}
	public static class PartitionOptionMaxRowsContext extends PartitionOptionContext {
		public DecimalLiteralContext maxRows;
		public TerminalNode MAX_ROWS() { return getToken(MariaDBParser.MAX_ROWS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionMaxRowsContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionOptionMaxRows(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionOptionMaxRows(this);
		}
	}
	public static class PartitionOptionTablespaceContext extends PartitionOptionContext {
		public UidContext tablespace;
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionTablespaceContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionOptionTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionOptionTablespace(this);
		}
	}
	public static class PartitionOptionEngineContext extends PartitionOptionContext {
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode STORAGE() { return getToken(MariaDBParser.STORAGE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionEngineContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionOptionEngine(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionOptionEngine(this);
		}
	}
	public static class PartitionOptionMinRowsContext extends PartitionOptionContext {
		public DecimalLiteralContext minRows;
		public TerminalNode MIN_ROWS() { return getToken(MariaDBParser.MIN_ROWS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionMinRowsContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionOptionMinRows(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionOptionMinRows(this);
		}
	}
	public static class PartitionOptionDataDirectoryContext extends PartitionOptionContext {
		public Token dataDirectory;
		public TerminalNode DATA() { return getToken(MariaDBParser.DATA, 0); }
		public TerminalNode DIRECTORY() { return getToken(MariaDBParser.DIRECTORY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionDataDirectoryContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionOptionDataDirectory(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionOptionDataDirectory(this);
		}
	}

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

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

				setState(2406);
				match(ENGINE);
				setState(2408);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2407);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2410);
				engineName();
				}
				break;
			case COMMENT:
				_localctx = new PartitionOptionCommentContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2411);
				match(COMMENT);
				setState(2413);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2412);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2415);
				((PartitionOptionCommentContext)_localctx).comment = match(STRING_LITERAL);
				}
				break;
			case DATA:
				_localctx = new PartitionOptionDataDirectoryContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2416);
				match(DATA);
				setState(2417);
				match(DIRECTORY);
				setState(2419);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2418);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2421);
				((PartitionOptionDataDirectoryContext)_localctx).dataDirectory = match(STRING_LITERAL);
				}
				break;
			case INDEX:
				_localctx = new PartitionOptionIndexDirectoryContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2422);
				match(INDEX);
				setState(2423);
				match(DIRECTORY);
				setState(2425);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2424);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2427);
				((PartitionOptionIndexDirectoryContext)_localctx).indexDirectory = match(STRING_LITERAL);
				}
				break;
			case MAX_ROWS:
				_localctx = new PartitionOptionMaxRowsContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2428);
				match(MAX_ROWS);
				setState(2430);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2429);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2432);
				((PartitionOptionMaxRowsContext)_localctx).maxRows = decimalLiteral();
				}
				break;
			case MIN_ROWS:
				_localctx = new PartitionOptionMinRowsContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(2433);
				match(MIN_ROWS);
				setState(2435);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2434);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2437);
				((PartitionOptionMinRowsContext)_localctx).minRows = decimalLiteral();
				}
				break;
			case TABLESPACE:
				_localctx = new PartitionOptionTablespaceContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(2438);
				match(TABLESPACE);
				setState(2440);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2439);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2442);
				((PartitionOptionTablespaceContext)_localctx).tablespace = uid();
				}
				break;
			case NODEGROUP:
				_localctx = new PartitionOptionNodeGroupContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(2443);
				match(NODEGROUP);
				setState(2445);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2444);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2447);
				((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;
	}

	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);
		}
	}
	public static class AlterUpgradeNameContext extends AlterDatabaseContext {
		public Token dbFormat;
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode UPGRADE() { return getToken(MariaDBParser.UPGRADE, 0); }
		public TerminalNode DATA() { return getToken(MariaDBParser.DATA, 0); }
		public TerminalNode DIRECTORY() { return getToken(MariaDBParser.DIRECTORY, 0); }
		public TerminalNode NAME() { return getToken(MariaDBParser.NAME, 0); }
		public TerminalNode DATABASE() { return getToken(MariaDBParser.DATABASE, 0); }
		public TerminalNode SCHEMA() { return getToken(MariaDBParser.SCHEMA, 0); }
		public AlterUpgradeNameContext(AlterDatabaseContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterUpgradeName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterUpgradeName(this);
		}
	}
	public static class AlterSimpleDatabaseContext extends AlterDatabaseContext {
		public Token dbFormat;
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode DATABASE() { return getToken(MariaDBParser.DATABASE, 0); }
		public TerminalNode SCHEMA() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterSimpleDatabase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterSimpleDatabase(this);
		}
	}

	public final AlterDatabaseContext alterDatabase() throws RecognitionException {
		AlterDatabaseContext _localctx = new AlterDatabaseContext(_ctx, getState());
		enterRule(_localctx, 134, RULE_alterDatabase);
		int _la;
		try {
			setState(2468);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,299,_ctx) ) {
			case 1:
				_localctx = new AlterSimpleDatabaseContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2450);
				match(ALTER);
				setState(2451);
				((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(2453);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,297,_ctx) ) {
				case 1:
					{
					setState(2452);
					uid();
					}
					break;
				}
				setState(2456); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(2455);
					createDatabaseOption();
					}
					}
					setState(2458); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( (((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << CHARACTER) | (1L << COLLATE) | (1L << DEFAULT))) != 0) || _la==READ || _la==CHAR || _la==ENCRYPTION || _la==CHARSET );
				}
				break;
			case 2:
				_localctx = new AlterUpgradeNameContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2460);
				match(ALTER);
				setState(2461);
				((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(2462);
				uid();
				setState(2463);
				match(UPGRADE);
				setState(2464);
				match(DATA);
				setState(2465);
				match(DIRECTORY);
				setState(2466);
				match(NAME);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class AlterEventContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode EVENT() { return getToken(MariaDBParser.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(MariaDBParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MariaDBParser.ON, i);
		}
		public TerminalNode SCHEDULE() { return getToken(MariaDBParser.SCHEDULE, 0); }
		public ScheduleExpressionContext scheduleExpression() {
			return getRuleContext(ScheduleExpressionContext.class,0);
		}
		public TerminalNode COMPLETION() { return getToken(MariaDBParser.COMPLETION, 0); }
		public TerminalNode PRESERVE() { return getToken(MariaDBParser.PRESERVE, 0); }
		public TerminalNode RENAME() { return getToken(MariaDBParser.RENAME, 0); }
		public TerminalNode TO() { return getToken(MariaDBParser.TO, 0); }
		public EnableTypeContext enableType() {
			return getRuleContext(EnableTypeContext.class,0);
		}
		public TerminalNode COMMENT() { return getToken(MariaDBParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode DO() { return getToken(MariaDBParser.DO, 0); }
		public RoutineBodyContext routineBody() {
			return getRuleContext(RoutineBodyContext.class,0);
		}
		public TerminalNode NOT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterEvent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterEvent(this);
		}
	}

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

			setState(2474);
			match(EVENT);
			setState(2475);
			fullId();
			setState(2479);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,301,_ctx) ) {
			case 1:
				{
				setState(2476);
				match(ON);
				setState(2477);
				match(SCHEDULE);
				setState(2478);
				scheduleExpression();
				}
				break;
			}
			setState(2487);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ON) {
				{
				setState(2481);
				match(ON);
				setState(2482);
				match(COMPLETION);
				setState(2484);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(2483);
					match(NOT);
					}
				}

				setState(2486);
				match(PRESERVE);
				}
			}

			setState(2492);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,304,_ctx) ) {
			case 1:
				{
				setState(2489);
				match(RENAME);
				setState(2490);
				match(TO);
				setState(2491);
				fullId();
				}
				break;
			}
			setState(2495);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DISABLE || _la==ENABLE) {
				{
				setState(2494);
				enableType();
				}
			}

			setState(2499);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMENT) {
				{
				setState(2497);
				match(COMMENT);
				setState(2498);
				match(STRING_LITERAL);
				}
			}

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

	public static class AlterFunctionContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode FUNCTION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterFunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterFunction(this);
		}
	}

	public final AlterFunctionContext alterFunction() throws RecognitionException {
		AlterFunctionContext _localctx = new AlterFunctionContext(_ctx, getState());
		enterRule(_localctx, 138, RULE_alterFunction);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2505);
			match(ALTER);
			setState(2506);
			match(FUNCTION);
			setState(2507);
			fullId();
			setState(2511);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DETERMINISTIC || ((((_la - 112)) & ~0x3f) == 0 && ((1L << (_la - 112)) & ((1L << (MODIFIES - 112)) | (1L << (NOT - 112)) | (1L << (READS - 112)) | (1L << (SQL - 112)))) != 0) || _la==COMMENT || _la==CONTAINS || _la==LANGUAGE || _la==NO) {
				{
				{
				setState(2508);
				routineOption();
				}
				}
				setState(2513);
				_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;
	}

	public static class AlterInstanceContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode INSTANCE() { return getToken(MariaDBParser.INSTANCE, 0); }
		public TerminalNode ROTATE() { return getToken(MariaDBParser.ROTATE, 0); }
		public TerminalNode INNODB() { return getToken(MariaDBParser.INNODB, 0); }
		public TerminalNode MASTER() { return getToken(MariaDBParser.MASTER, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterInstance(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterInstance(this);
		}
	}

	public final AlterInstanceContext alterInstance() throws RecognitionException {
		AlterInstanceContext _localctx = new AlterInstanceContext(_ctx, getState());
		enterRule(_localctx, 140, RULE_alterInstance);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2514);
			match(ALTER);
			setState(2515);
			match(INSTANCE);
			setState(2516);
			match(ROTATE);
			setState(2517);
			match(INNODB);
			setState(2518);
			match(MASTER);
			setState(2519);
			match(KEY);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class AlterLogfileGroupContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode LOGFILE() { return getToken(MariaDBParser.LOGFILE, 0); }
		public TerminalNode GROUP() { return getToken(MariaDBParser.GROUP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode UNDOFILE() { return getToken(MariaDBParser.UNDOFILE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TerminalNode INITIAL_SIZE() { return getToken(MariaDBParser.INITIAL_SIZE, 0); }
		public FileSizeLiteralContext fileSizeLiteral() {
			return getRuleContext(FileSizeLiteralContext.class,0);
		}
		public TerminalNode WAIT() { return getToken(MariaDBParser.WAIT, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterLogfileGroup(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterLogfileGroup(this);
		}
	}

	public final AlterLogfileGroupContext alterLogfileGroup() throws RecognitionException {
		AlterLogfileGroupContext _localctx = new AlterLogfileGroupContext(_ctx, getState());
		enterRule(_localctx, 142, RULE_alterLogfileGroup);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2521);
			match(ALTER);
			setState(2522);
			match(LOGFILE);
			setState(2523);
			match(GROUP);
			setState(2524);
			uid();
			setState(2525);
			match(ADD);
			setState(2526);
			match(UNDOFILE);
			setState(2527);
			match(STRING_LITERAL);
			setState(2533);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INITIAL_SIZE) {
				{
				setState(2528);
				match(INITIAL_SIZE);
				setState(2530);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2529);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2532);
				fileSizeLiteral();
				}
			}

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

			setState(2538);
			match(ENGINE);
			setState(2540);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EQUAL_SYMBOL) {
				{
				setState(2539);
				match(EQUAL_SYMBOL);
				}
			}

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

	public static class AlterProcedureContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode PROCEDURE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterProcedure(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterProcedure(this);
		}
	}

	public final AlterProcedureContext alterProcedure() throws RecognitionException {
		AlterProcedureContext _localctx = new AlterProcedureContext(_ctx, getState());
		enterRule(_localctx, 144, RULE_alterProcedure);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2544);
			match(ALTER);
			setState(2545);
			match(PROCEDURE);
			setState(2546);
			fullId();
			setState(2550);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DETERMINISTIC || ((((_la - 112)) & ~0x3f) == 0 && ((1L << (_la - 112)) & ((1L << (MODIFIES - 112)) | (1L << (NOT - 112)) | (1L << (READS - 112)) | (1L << (SQL - 112)))) != 0) || _la==COMMENT || _la==CONTAINS || _la==LANGUAGE || _la==NO) {
				{
				{
				setState(2547);
				routineOption();
				}
				}
				setState(2552);
				_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;
	}

	public static class AlterServerContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode SERVER() { return getToken(MariaDBParser.SERVER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode OPTIONS() { return getToken(MariaDBParser.OPTIONS, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterServer(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterServer(this);
		}
	}

	public final AlterServerContext alterServer() throws RecognitionException {
		AlterServerContext _localctx = new AlterServerContext(_ctx, getState());
		enterRule(_localctx, 146, RULE_alterServer);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2553);
			match(ALTER);
			setState(2554);
			match(SERVER);
			setState(2555);
			uid();
			setState(2556);
			match(OPTIONS);
			setState(2557);
			match(LR_BRACKET);
			setState(2558);
			serverOption();
			setState(2563);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(2559);
				match(COMMA);
				setState(2560);
				serverOption();
				}
				}
				setState(2565);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2566);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class AlterTableContext extends ParserRuleContext {
		public Token intimeAction;
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode IGNORE() { return getToken(MariaDBParser.IGNORE, 0); }
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,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(MariaDBParser.ONLINE, 0); }
		public TerminalNode OFFLINE() { return getToken(MariaDBParser.OFFLINE, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterTable(this);
		}
	}

	public final AlterTableContext alterTable() throws RecognitionException {
		AlterTableContext _localctx = new AlterTableContext(_ctx, getState());
		enterRule(_localctx, 148, RULE_alterTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2568);
			match(ALTER);
			setState(2570);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OFFLINE || _la==ONLINE) {
				{
				setState(2569);
				((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(2573);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(2572);
				match(IGNORE);
				}
			}

			setState(2575);
			match(TABLE);
			setState(2577);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,317,_ctx) ) {
			case 1:
				{
				setState(2576);
				ifExists();
				}
				break;
			}
			setState(2579);
			tableName();
			setState(2581);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOWAIT || _la==WAIT) {
				{
				setState(2580);
				waitNowaitClause();
				}
			}

			setState(2591);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,320,_ctx) ) {
			case 1:
				{
				setState(2583);
				alterSpecification();
				setState(2588);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2584);
					match(COMMA);
					setState(2585);
					alterSpecification();
					}
					}
					setState(2590);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
			setState(2594);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(2593);
				partitionDefinitions();
				}
			}

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

	public static class AlterTablespaceContext extends ParserRuleContext {
		public Token objectAction;
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DATAFILE() { return getToken(MariaDBParser.DATAFILE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode INITIAL_SIZE() { return getToken(MariaDBParser.INITIAL_SIZE, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.EQUAL_SYMBOL, i);
		}
		public FileSizeLiteralContext fileSizeLiteral() {
			return getRuleContext(FileSizeLiteralContext.class,0);
		}
		public TerminalNode WAIT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterTablespace(this);
		}
	}

	public final AlterTablespaceContext alterTablespace() throws RecognitionException {
		AlterTablespaceContext _localctx = new AlterTablespaceContext(_ctx, getState());
		enterRule(_localctx, 150, RULE_alterTablespace);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2596);
			match(ALTER);
			setState(2597);
			match(TABLESPACE);
			setState(2598);
			uid();
			setState(2599);
			((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(2600);
			match(DATAFILE);
			setState(2601);
			match(STRING_LITERAL);
			setState(2605);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INITIAL_SIZE) {
				{
				setState(2602);
				match(INITIAL_SIZE);
				setState(2603);
				match(EQUAL_SYMBOL);
				setState(2604);
				fileSizeLiteral();
				}
			}

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

			setState(2610);
			match(ENGINE);
			setState(2612);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EQUAL_SYMBOL) {
				{
				setState(2611);
				match(EQUAL_SYMBOL);
				}
			}

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

	public static class AlterViewContext extends ParserRuleContext {
		public Token algType;
		public Token secContext;
		public Token checkOpt;
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode VIEW() { return getToken(MariaDBParser.VIEW, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public TerminalNode ALGORITHM() { return getToken(MariaDBParser.ALGORITHM, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public TerminalNode SQL() { return getToken(MariaDBParser.SQL, 0); }
		public TerminalNode SECURITY() { return getToken(MariaDBParser.SECURITY, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public TerminalNode CHECK() { return getToken(MariaDBParser.CHECK, 0); }
		public TerminalNode OPTION() { return getToken(MariaDBParser.OPTION, 0); }
		public TerminalNode UNDEFINED() { return getToken(MariaDBParser.UNDEFINED, 0); }
		public TerminalNode MERGE() { return getToken(MariaDBParser.MERGE, 0); }
		public TerminalNode TEMPTABLE() { return getToken(MariaDBParser.TEMPTABLE, 0); }
		public TerminalNode DEFINER() { return getToken(MariaDBParser.DEFINER, 0); }
		public TerminalNode INVOKER() { return getToken(MariaDBParser.INVOKER, 0); }
		public TerminalNode CASCADED() { return getToken(MariaDBParser.CASCADED, 0); }
		public TerminalNode LOCAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterView(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterView(this);
		}
	}

	public final AlterViewContext alterView() throws RecognitionException {
		AlterViewContext _localctx = new AlterViewContext(_ctx, getState());
		enterRule(_localctx, 152, RULE_alterView);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2616);
			match(ALTER);
			setState(2620);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ALGORITHM) {
				{
				setState(2617);
				match(ALGORITHM);
				setState(2618);
				match(EQUAL_SYMBOL);
				setState(2619);
				((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(2623);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFINER) {
				{
				setState(2622);
				ownerStatement();
				}
			}

			setState(2628);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==SQL) {
				{
				setState(2625);
				match(SQL);
				setState(2626);
				match(SECURITY);
				setState(2627);
				((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(2630);
			match(VIEW);
			setState(2631);
			fullId();
			setState(2636);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LR_BRACKET) {
				{
				setState(2632);
				match(LR_BRACKET);
				setState(2633);
				uidList();
				setState(2634);
				match(RR_BRACKET);
				}
			}

			setState(2638);
			match(AS);
			setState(2639);
			selectStatement();
			setState(2646);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WITH) {
				{
				setState(2640);
				match(WITH);
				setState(2642);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CASCADED || _la==LOCAL) {
					{
					setState(2641);
					((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(2644);
				match(CHECK);
				setState(2645);
				match(OPTION);
				}
			}

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

	public static class AlterSequenceContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode SEQUENCE() { return getToken(MariaDBParser.SEQUENCE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public List sequenceSpec() {
			return getRuleContexts(SequenceSpecContext.class);
		}
		public SequenceSpecContext sequenceSpec(int i) {
			return getRuleContext(SequenceSpecContext.class,i);
		}
		public AlterSequenceContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterSequence; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterSequence(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterSequence(this);
		}
	}

	public final AlterSequenceContext alterSequence() throws RecognitionException {
		AlterSequenceContext _localctx = new AlterSequenceContext(_ctx, getState());
		enterRule(_localctx, 154, RULE_alterSequence);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2648);
			match(ALTER);
			setState(2649);
			match(SEQUENCE);
			setState(2651);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,331,_ctx) ) {
			case 1:
				{
				setState(2650);
				ifExists();
				}
				break;
			}
			setState(2653);
			fullId();
			setState(2655); 
			_errHandler.sync(this);
			_alt = 1;
			do {
				switch (_alt) {
				case 1:
					{
					{
					setState(2654);
					sequenceSpec();
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(2657); 
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,332,_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;
	}

	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);
		}
	}
	public static class AlterByDisableKeysContext extends AlterSpecificationContext {
		public TerminalNode DISABLE() { return getToken(MariaDBParser.DISABLE, 0); }
		public TerminalNode KEYS() { return getToken(MariaDBParser.KEYS, 0); }
		public AlterByDisableKeysContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByDisableKeys(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByDisableKeys(this);
		}
	}
	public static class AlterByDefaultCharsetContext extends AlterSpecificationContext {
		public TerminalNode CHARACTER() { return getToken(MariaDBParser.CHARACTER, 0); }
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.EQUAL_SYMBOL, i);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode COLLATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByDefaultCharset(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByDefaultCharset(this);
		}
	}
	public static class AlterByRenameColumnContext extends AlterSpecificationContext {
		public UidContext oldColumn;
		public UidContext newColumn;
		public TerminalNode RENAME() { return getToken(MariaDBParser.RENAME, 0); }
		public TerminalNode COLUMN() { return getToken(MariaDBParser.COLUMN, 0); }
		public TerminalNode TO() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByRenameColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByRenameColumn(this);
		}
	}
	public static class AlterByConvertCharsetContext extends AlterSpecificationContext {
		public TerminalNode CONVERT() { return getToken(MariaDBParser.CONVERT, 0); }
		public TerminalNode TO() { return getToken(MariaDBParser.TO, 0); }
		public TerminalNode CHARACTER() { return getToken(MariaDBParser.CHARACTER, 0); }
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode COLLATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByConvertCharset(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByConvertCharset(this);
		}
	}
	public static class AlterByAddForeignKeyContext extends AlterSpecificationContext {
		public UidContext name;
		public UidContext indexName;
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode FOREIGN() { return getToken(MariaDBParser.FOREIGN, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public ReferenceDefinitionContext referenceDefinition() {
			return getRuleContext(ReferenceDefinitionContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MariaDBParser.CONSTRAINT, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAddForeignKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAddForeignKey(this);
		}
	}
	public static class AlterByRenameIndexContext extends AlterSpecificationContext {
		public Token indexFormat;
		public TerminalNode RENAME() { return getToken(MariaDBParser.RENAME, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode TO() { return getToken(MariaDBParser.TO, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public AlterByRenameIndexContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByRenameIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByRenameIndex(this);
		}
	}
	public static class AlterByRenameContext extends AlterSpecificationContext {
		public Token renameFormat;
		public TerminalNode RENAME() { return getToken(MariaDBParser.RENAME, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode TO() { return getToken(MariaDBParser.TO, 0); }
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public AlterByRenameContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByRename(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByRename(this);
		}
	}
	public static class AlterByImportTablespaceContext extends AlterSpecificationContext {
		public TerminalNode IMPORT() { return getToken(MariaDBParser.IMPORT, 0); }
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public AlterByImportTablespaceContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByImportTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByImportTablespace(this);
		}
	}
	public static class AlterByAddDefinitionsContext extends AlterSpecificationContext {
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode COLUMN() { return getToken(MariaDBParser.COLUMN, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public AlterByAddDefinitionsContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAddDefinitions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAddDefinitions(this);
		}
	}
	public static class AlterByDropConstraintCheckContext extends AlterSpecificationContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MariaDBParser.CONSTRAINT, 0); }
		public TerminalNode CHECK() { return getToken(MariaDBParser.CHECK, 0); }
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public AlterByDropConstraintCheckContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByDropConstraintCheck(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByDropConstraintCheck(this);
		}
	}
	public static class AlterByAddColumnsContext extends AlterSpecificationContext {
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode COLUMN() { return getToken(MariaDBParser.COLUMN, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public AlterByAddColumnsContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAddColumns(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAddColumns(this);
		}
	}
	public static class AlterByAlterIndexVisibilityContext extends AlterSpecificationContext {
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode VISIBLE() { return getToken(MariaDBParser.VISIBLE, 0); }
		public TerminalNode INVISIBLE() { return getToken(MariaDBParser.INVISIBLE, 0); }
		public AlterByAlterIndexVisibilityContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAlterIndexVisibility(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAlterIndexVisibility(this);
		}
	}
	public static class AlterByDropForeignKeyContext extends AlterSpecificationContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode FOREIGN() { return getToken(MariaDBParser.FOREIGN, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public DottedIdContext dottedId() {
			return getRuleContext(DottedIdContext.class,0);
		}
		public AlterByDropForeignKeyContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByDropForeignKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByDropForeignKey(this);
		}
	}
	public static class AlterByAddCheckTableConstraintContext extends AlterSpecificationContext {
		public UidContext name;
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode CHECK() { return getToken(MariaDBParser.CHECK, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode CONSTRAINT() { return getToken(MariaDBParser.CONSTRAINT, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public AlterByAddCheckTableConstraintContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAddCheckTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAddCheckTableConstraint(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterPartition(this);
		}
	}
	public static class AlterByAddIndexContext extends AlterSpecificationContext {
		public Token indexFormat;
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAddIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAddIndex(this);
		}
	}
	public static class AlterByDropColumnContext extends AlterSpecificationContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode COLUMN() { return getToken(MariaDBParser.COLUMN, 0); }
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public TerminalNode RESTRICT() { return getToken(MariaDBParser.RESTRICT, 0); }
		public AlterByDropColumnContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByDropColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByDropColumn(this);
		}
	}
	public static class AlterByChangeDefaultContext extends AlterSpecificationContext {
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public DefaultValueContext defaultValue() {
			return getRuleContext(DefaultValueContext.class,0);
		}
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode COLUMN() { return getToken(MariaDBParser.COLUMN, 0); }
		public AlterByChangeDefaultContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByChangeDefault(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByChangeDefault(this);
		}
	}
	public static class AlterByForceContext extends AlterSpecificationContext {
		public TerminalNode FORCE() { return getToken(MariaDBParser.FORCE, 0); }
		public AlterByForceContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByForce(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByForce(this);
		}
	}
	public static class AlterByAddSpecialIndexContext extends AlterSpecificationContext {
		public Token keyType;
		public Token indexFormat;
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode FULLTEXT() { return getToken(MariaDBParser.FULLTEXT, 0); }
		public TerminalNode SPATIAL() { return getToken(MariaDBParser.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(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public AlterByAddSpecialIndexContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAddSpecialIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAddSpecialIndex(this);
		}
	}
	public static class AlterByModifyColumnContext extends AlterSpecificationContext {
		public TerminalNode MODIFY() { return getToken(MariaDBParser.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(MariaDBParser.COLUMN, 0); }
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public TerminalNode FIRST() { return getToken(MariaDBParser.FIRST, 0); }
		public TerminalNode AFTER() { return getToken(MariaDBParser.AFTER, 0); }
		public AlterByModifyColumnContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByModifyColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByModifyColumn(this);
		}
	}
	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public AlterByTableOptionContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByTableOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByTableOption(this);
		}
	}
	public static class AlterByDropPrimaryKeyContext extends AlterSpecificationContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode PRIMARY() { return getToken(MariaDBParser.PRIMARY, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public AlterByDropPrimaryKeyContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByDropPrimaryKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByDropPrimaryKey(this);
		}
	}
	public static class AlterByLockContext extends AlterSpecificationContext {
		public Token lockType;
		public TerminalNode LOCK() { return getToken(MariaDBParser.LOCK, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode NONE() { return getToken(MariaDBParser.NONE, 0); }
		public TerminalNode SHARED() { return getToken(MariaDBParser.SHARED, 0); }
		public TerminalNode EXCLUSIVE() { return getToken(MariaDBParser.EXCLUSIVE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public AlterByLockContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByLock(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByLock(this);
		}
	}
	public static class AlterByDiscardTablespaceContext extends AlterSpecificationContext {
		public TerminalNode DISCARD() { return getToken(MariaDBParser.DISCARD, 0); }
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public AlterByDiscardTablespaceContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByDiscardTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByDiscardTablespace(this);
		}
	}
	public static class AlterByValidateContext extends AlterSpecificationContext {
		public Token validationFormat;
		public TerminalNode VALIDATION() { return getToken(MariaDBParser.VALIDATION, 0); }
		public TerminalNode WITHOUT() { return getToken(MariaDBParser.WITHOUT, 0); }
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public AlterByValidateContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByValidate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByValidate(this);
		}
	}
	public static class AlterByAddPrimaryKeyContext extends AlterSpecificationContext {
		public UidContext name;
		public UidContext index;
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode PRIMARY() { return getToken(MariaDBParser.PRIMARY, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAddPrimaryKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAddPrimaryKey(this);
		}
	}
	public static class AlterByEnableKeysContext extends AlterSpecificationContext {
		public TerminalNode ENABLE() { return getToken(MariaDBParser.ENABLE, 0); }
		public TerminalNode KEYS() { return getToken(MariaDBParser.KEYS, 0); }
		public AlterByEnableKeysContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByEnableKeys(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByEnableKeys(this);
		}
	}
	public static class AlterBySetAlgorithmContext extends AlterSpecificationContext {
		public Token algType;
		public TerminalNode ALGORITHM() { return getToken(MariaDBParser.ALGORITHM, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode INSTANT() { return getToken(MariaDBParser.INSTANT, 0); }
		public TerminalNode INPLACE() { return getToken(MariaDBParser.INPLACE, 0); }
		public TerminalNode COPY() { return getToken(MariaDBParser.COPY, 0); }
		public TerminalNode NOCOPY() { return getToken(MariaDBParser.NOCOPY, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public AlterBySetAlgorithmContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterBySetAlgorithm(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterBySetAlgorithm(this);
		}
	}
	public static class AlterByChangeColumnContext extends AlterSpecificationContext {
		public UidContext oldColumn;
		public UidContext newColumn;
		public UidContext afterColumn;
		public TerminalNode CHANGE() { return getToken(MariaDBParser.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(MariaDBParser.COLUMN, 0); }
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public TerminalNode FIRST() { return getToken(MariaDBParser.FIRST, 0); }
		public TerminalNode AFTER() { return getToken(MariaDBParser.AFTER, 0); }
		public AlterByChangeColumnContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByChangeColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByChangeColumn(this);
		}
	}
	public static class AlterByAddUniqueKeyContext extends AlterSpecificationContext {
		public UidContext name;
		public Token indexFormat;
		public UidContext indexName;
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode UNIQUE() { return getToken(MariaDBParser.UNIQUE, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MariaDBParser.CONSTRAINT, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.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 uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public AlterByAddUniqueKeyContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAddUniqueKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAddUniqueKey(this);
		}
	}
	public static class AlterByDropIndexContext extends AlterSpecificationContext {
		public Token indexFormat;
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public AlterByDropIndexContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByDropIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByDropIndex(this);
		}
	}
	public static class AlterByAddColumnContext extends AlterSpecificationContext {
		public TerminalNode ADD() { return getToken(MariaDBParser.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(MariaDBParser.COLUMN, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public TerminalNode FIRST() { return getToken(MariaDBParser.FIRST, 0); }
		public TerminalNode AFTER() { return getToken(MariaDBParser.AFTER, 0); }
		public AlterByAddColumnContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAddColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAddColumn(this);
		}
	}
	public static class AlterByOrderContext extends AlterSpecificationContext {
		public TerminalNode ORDER() { return getToken(MariaDBParser.ORDER, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByOrder(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByOrder(this);
		}
	}

	public final AlterSpecificationContext alterSpecification() throws RecognitionException {
		AlterSpecificationContext _localctx = new AlterSpecificationContext(_ctx, getState());
		enterRule(_localctx, 156, RULE_alterSpecification);
		int _la;
		try {
			int _alt;
			setState(2982);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,391,_ctx) ) {
			case 1:
				_localctx = new AlterByTableOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2659);
				tableOption();
				setState(2666);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,334,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(2661);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==COMMA) {
							{
							setState(2660);
							match(COMMA);
							}
						}

						setState(2663);
						tableOption();
						}
						} 
					}
					setState(2668);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,334,_ctx);
				}
				}
				break;
			case 2:
				_localctx = new AlterByAddColumnContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2669);
				match(ADD);
				setState(2671);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2670);
					match(COLUMN);
					}
				}

				setState(2674);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,336,_ctx) ) {
				case 1:
					{
					setState(2673);
					ifNotExists();
					}
					break;
				}
				setState(2676);
				uid();
				setState(2677);
				columnDefinition();
				setState(2681);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case FIRST:
					{
					setState(2678);
					match(FIRST);
					}
					break;
				case AFTER:
					{
					setState(2679);
					match(AFTER);
					setState(2680);
					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 UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				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(2683);
				match(ADD);
				setState(2685);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2684);
					match(COLUMN);
					}
				}

				setState(2688);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IF) {
					{
					setState(2687);
					ifNotExists();
					}
				}

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

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

				setState(2715);
				indexColumnNames();
				setState(2719);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==IGNORED || _la==NOT || _la==USING || _la==WITH || _la==CLUSTERING || _la==COMMENT || _la==INVISIBLE || _la==KEY_BLOCK_SIZE || _la==VISIBLE || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE) {
					{
					{
					setState(2716);
					indexOption();
					}
					}
					setState(2721);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 5:
				_localctx = new AlterByAddPrimaryKeyContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2722);
				match(ADD);
				setState(2727);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(2723);
					match(CONSTRAINT);
					setState(2725);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,345,_ctx) ) {
					case 1:
						{
						setState(2724);
						((AlterByAddPrimaryKeyContext)_localctx).name = uid();
						}
						break;
					}
					}
				}

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

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

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

					}
				}

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

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

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

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

					}
				}

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

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

					}
				}

				setState(2811);
				match(CHECK);
				setState(2812);
				match(LR_BRACKET);
				setState(2813);
				expression(0);
				setState(2814);
				match(RR_BRACKET);
				}
				break;
			case 10:
				_localctx = new AlterBySetAlgorithmContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(2816);
				match(ALGORITHM);
				setState(2818);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2817);
					match(EQUAL_SYMBOL);
					}
				}

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

				setState(2825);
				uid();
				setState(2831);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case SET:
					{
					setState(2826);
					match(SET);
					setState(2827);
					match(DEFAULT);
					setState(2828);
					defaultValue();
					}
					break;
				case DROP:
					{
					setState(2829);
					match(DROP);
					setState(2830);
					match(DEFAULT);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 12:
				_localctx = new AlterByChangeColumnContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(2833);
				match(CHANGE);
				setState(2835);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2834);
					match(COLUMN);
					}
				}

				setState(2838);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,370,_ctx) ) {
				case 1:
					{
					setState(2837);
					ifExists();
					}
					break;
				}
				setState(2840);
				((AlterByChangeColumnContext)_localctx).oldColumn = uid();
				setState(2841);
				((AlterByChangeColumnContext)_localctx).newColumn = uid();
				setState(2842);
				columnDefinition();
				setState(2846);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case FIRST:
					{
					setState(2843);
					match(FIRST);
					}
					break;
				case AFTER:
					{
					setState(2844);
					match(AFTER);
					setState(2845);
					((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 UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				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 13:
				_localctx = new AlterByRenameColumnContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(2848);
				match(RENAME);
				setState(2849);
				match(COLUMN);
				setState(2850);
				((AlterByRenameColumnContext)_localctx).oldColumn = uid();
				setState(2851);
				match(TO);
				setState(2852);
				((AlterByRenameColumnContext)_localctx).newColumn = uid();
				}
				break;
			case 14:
				_localctx = new AlterByLockContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(2854);
				match(LOCK);
				setState(2856);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2855);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2858);
				((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 15:
				_localctx = new AlterByModifyColumnContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(2859);
				match(MODIFY);
				setState(2861);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2860);
					match(COLUMN);
					}
				}

				setState(2864);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,374,_ctx) ) {
				case 1:
					{
					setState(2863);
					ifExists();
					}
					break;
				}
				setState(2866);
				uid();
				setState(2867);
				columnDefinition();
				setState(2871);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case FIRST:
					{
					setState(2868);
					match(FIRST);
					}
					break;
				case AFTER:
					{
					setState(2869);
					match(AFTER);
					setState(2870);
					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 UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				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 16:
				_localctx = new AlterByDropColumnContext(_localctx);
				enterOuterAlt(_localctx, 16);
				{
				setState(2873);
				match(DROP);
				setState(2875);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2874);
					match(COLUMN);
					}
				}

				setState(2878);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,377,_ctx) ) {
				case 1:
					{
					setState(2877);
					ifExists();
					}
					break;
				}
				setState(2880);
				uid();
				setState(2882);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==RESTRICT) {
					{
					setState(2881);
					match(RESTRICT);
					}
				}

				}
				break;
			case 17:
				_localctx = new AlterByDropConstraintCheckContext(_localctx);
				enterOuterAlt(_localctx, 17);
				{
				setState(2884);
				match(DROP);
				setState(2885);
				_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(2887);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,379,_ctx) ) {
				case 1:
					{
					setState(2886);
					ifExists();
					}
					break;
				}
				setState(2889);
				uid();
				}
				break;
			case 18:
				_localctx = new AlterByDropPrimaryKeyContext(_localctx);
				enterOuterAlt(_localctx, 18);
				{
				setState(2890);
				match(DROP);
				setState(2891);
				match(PRIMARY);
				setState(2892);
				match(KEY);
				}
				break;
			case 19:
				_localctx = new AlterByDropIndexContext(_localctx);
				enterOuterAlt(_localctx, 19);
				{
				setState(2893);
				match(DROP);
				setState(2894);
				((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(2896);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,380,_ctx) ) {
				case 1:
					{
					setState(2895);
					ifExists();
					}
					break;
				}
				setState(2898);
				uid();
				}
				break;
			case 20:
				_localctx = new AlterByRenameIndexContext(_localctx);
				enterOuterAlt(_localctx, 20);
				{
				setState(2899);
				match(RENAME);
				setState(2900);
				((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(2901);
				uid();
				setState(2902);
				match(TO);
				setState(2903);
				uid();
				}
				break;
			case 21:
				_localctx = new AlterByAlterIndexVisibilityContext(_localctx);
				enterOuterAlt(_localctx, 21);
				{
				setState(2905);
				match(ALTER);
				setState(2906);
				match(INDEX);
				setState(2907);
				uid();
				setState(2908);
				_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 22:
				_localctx = new AlterByDropForeignKeyContext(_localctx);
				enterOuterAlt(_localctx, 22);
				{
				setState(2910);
				match(DROP);
				setState(2911);
				match(FOREIGN);
				setState(2912);
				match(KEY);
				setState(2914);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,381,_ctx) ) {
				case 1:
					{
					setState(2913);
					ifExists();
					}
					break;
				}
				setState(2916);
				uid();
				setState(2918);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DOT || _la==DOT_ID) {
					{
					setState(2917);
					dottedId();
					}
				}

				}
				break;
			case 23:
				_localctx = new AlterByDisableKeysContext(_localctx);
				enterOuterAlt(_localctx, 23);
				{
				setState(2920);
				match(DISABLE);
				setState(2921);
				match(KEYS);
				}
				break;
			case 24:
				_localctx = new AlterByEnableKeysContext(_localctx);
				enterOuterAlt(_localctx, 24);
				{
				setState(2922);
				match(ENABLE);
				setState(2923);
				match(KEYS);
				}
				break;
			case 25:
				_localctx = new AlterByRenameContext(_localctx);
				enterOuterAlt(_localctx, 25);
				{
				setState(2924);
				match(RENAME);
				setState(2926);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS || _la==TO) {
					{
					setState(2925);
					((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(2930);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,384,_ctx) ) {
				case 1:
					{
					setState(2928);
					uid();
					}
					break;
				case 2:
					{
					setState(2929);
					fullId();
					}
					break;
				}
				}
				break;
			case 26:
				_localctx = new AlterByOrderContext(_localctx);
				enterOuterAlt(_localctx, 26);
				{
				setState(2932);
				match(ORDER);
				setState(2933);
				match(BY);
				setState(2934);
				uidList();
				}
				break;
			case 27:
				_localctx = new AlterByConvertCharsetContext(_localctx);
				enterOuterAlt(_localctx, 27);
				{
				setState(2935);
				match(CONVERT);
				setState(2936);
				match(TO);
				setState(2937);
				match(CHARACTER);
				setState(2938);
				match(SET);
				setState(2939);
				charsetName();
				setState(2942);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLLATE) {
					{
					setState(2940);
					match(COLLATE);
					setState(2941);
					collationName();
					}
				}

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

				setState(2947);
				match(CHARACTER);
				setState(2948);
				match(SET);
				setState(2949);
				match(EQUAL_SYMBOL);
				setState(2950);
				charsetName();
				setState(2954);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLLATE) {
					{
					setState(2951);
					match(COLLATE);
					setState(2952);
					match(EQUAL_SYMBOL);
					setState(2953);
					collationName();
					}
				}

				}
				break;
			case 29:
				_localctx = new AlterByDiscardTablespaceContext(_localctx);
				enterOuterAlt(_localctx, 29);
				{
				setState(2956);
				match(DISCARD);
				setState(2957);
				match(TABLESPACE);
				}
				break;
			case 30:
				_localctx = new AlterByImportTablespaceContext(_localctx);
				enterOuterAlt(_localctx, 30);
				{
				setState(2958);
				match(IMPORT);
				setState(2959);
				match(TABLESPACE);
				}
				break;
			case 31:
				_localctx = new AlterByForceContext(_localctx);
				enterOuterAlt(_localctx, 31);
				{
				setState(2960);
				match(FORCE);
				}
				break;
			case 32:
				_localctx = new AlterByValidateContext(_localctx);
				enterOuterAlt(_localctx, 32);
				{
				setState(2961);
				((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(2962);
				match(VALIDATION);
				}
				break;
			case 33:
				_localctx = new AlterByAddDefinitionsContext(_localctx);
				enterOuterAlt(_localctx, 33);
				{
				setState(2963);
				match(ADD);
				setState(2965);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2964);
					match(COLUMN);
					}
				}

				setState(2968);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IF) {
					{
					setState(2967);
					ifNotExists();
					}
				}

				setState(2970);
				match(LR_BRACKET);
				setState(2971);
				createDefinition();
				setState(2976);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2972);
					match(COMMA);
					setState(2973);
					createDefinition();
					}
					}
					setState(2978);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2979);
				match(RR_BRACKET);
				}
				break;
			case 34:
				_localctx = new AlterPartitionContext(_localctx);
				enterOuterAlt(_localctx, 34);
				{
				setState(2981);
				alterPartitionSpecification();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class AlterByImportPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode IMPORT() { return getToken(MariaDBParser.IMPORT, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public AlterByImportPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByImportPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByImportPartition(this);
		}
	}
	public static class AlterByDropPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public AlterByDropPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByDropPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByDropPartition(this);
		}
	}
	public static class AlterByDiscardPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode DISCARD() { return getToken(MariaDBParser.DISCARD, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public AlterByDiscardPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByDiscardPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByDiscardPartition(this);
		}
	}
	public static class AlterByAddPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode ADD() { return getToken(MariaDBParser.ADD, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public AlterByAddPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAddPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAddPartition(this);
		}
	}
	public static class AlterByRemovePartitioningContext extends AlterPartitionSpecificationContext {
		public TerminalNode REMOVE() { return getToken(MariaDBParser.REMOVE, 0); }
		public TerminalNode PARTITIONING() { return getToken(MariaDBParser.PARTITIONING, 0); }
		public AlterByRemovePartitioningContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByRemovePartitioning(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByRemovePartitioning(this);
		}
	}
	public static class AlterByOptimizePartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode OPTIMIZE() { return getToken(MariaDBParser.OPTIMIZE, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public AlterByOptimizePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByOptimizePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByOptimizePartition(this);
		}
	}
	public static class AlterByCheckPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode CHECK() { return getToken(MariaDBParser.CHECK, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public AlterByCheckPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByCheckPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByCheckPartition(this);
		}
	}
	public static class AlterByCoalescePartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode COALESCE() { return getToken(MariaDBParser.COALESCE, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByCoalescePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByCoalescePartition(this);
		}
	}
	public static class AlterByReorganizePartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode REORGANIZE() { return getToken(MariaDBParser.REORGANIZE, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public AlterByReorganizePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByReorganizePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByReorganizePartition(this);
		}
	}
	public static class AlterByAnalyzePartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode ANALYZE() { return getToken(MariaDBParser.ANALYZE, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public AlterByAnalyzePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByAnalyzePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByAnalyzePartition(this);
		}
	}
	public static class AlterByRebuildPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode REBUILD() { return getToken(MariaDBParser.REBUILD, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public AlterByRebuildPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByRebuildPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByRebuildPartition(this);
		}
	}
	public static class AlterByUpgradePartitioningContext extends AlterPartitionSpecificationContext {
		public TerminalNode UPGRADE() { return getToken(MariaDBParser.UPGRADE, 0); }
		public TerminalNode PARTITIONING() { return getToken(MariaDBParser.PARTITIONING, 0); }
		public AlterByUpgradePartitioningContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByUpgradePartitioning(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByUpgradePartitioning(this);
		}
	}
	public static class AlterByTruncatePartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode TRUNCATE() { return getToken(MariaDBParser.TRUNCATE, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public AlterByTruncatePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByTruncatePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByTruncatePartition(this);
		}
	}
	public static class AlterByRepairPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode REPAIR() { return getToken(MariaDBParser.REPAIR, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public AlterByRepairPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByRepairPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByRepairPartition(this);
		}
	}
	public static class AlterByExchangePartitionContext extends AlterPartitionSpecificationContext {
		public Token validationFormat;
		public TerminalNode EXCHANGE() { return getToken(MariaDBParser.EXCHANGE, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List WITH() { return getTokens(MariaDBParser.WITH); }
		public TerminalNode WITH(int i) {
			return getToken(MariaDBParser.WITH, i);
		}
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode VALIDATION() { return getToken(MariaDBParser.VALIDATION, 0); }
		public TerminalNode WITHOUT() { return getToken(MariaDBParser.WITHOUT, 0); }
		public AlterByExchangePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterByExchangePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterByExchangePartition(this);
		}
	}

	public final AlterPartitionSpecificationContext alterPartitionSpecification() throws RecognitionException {
		AlterPartitionSpecificationContext _localctx = new AlterPartitionSpecificationContext(_ctx, getState());
		enterRule(_localctx, 158, RULE_alterPartitionSpecification);
		int _la;
		try {
			setState(3088);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ADD:
				_localctx = new AlterByAddPartitionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2984);
				match(ADD);
				setState(2985);
				match(PARTITION);
				setState(2987);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IF) {
					{
					setState(2986);
					ifNotExists();
					}
				}

				setState(2989);
				match(LR_BRACKET);
				setState(2990);
				partitionDefinition();
				setState(2995);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2991);
					match(COMMA);
					setState(2992);
					partitionDefinition();
					}
					}
					setState(2997);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2998);
				match(RR_BRACKET);
				}
				break;
			case DROP:
				_localctx = new AlterByDropPartitionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(3000);
				match(DROP);
				setState(3001);
				match(PARTITION);
				setState(3003);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,394,_ctx) ) {
				case 1:
					{
					setState(3002);
					ifExists();
					}
					break;
				}
				setState(3005);
				uidList();
				}
				break;
			case DISCARD:
				_localctx = new AlterByDiscardPartitionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(3006);
				match(DISCARD);
				setState(3007);
				match(PARTITION);
				setState(3010);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(3008);
					uidList();
					}
					break;
				case ALL:
					{
					setState(3009);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(3012);
				match(TABLESPACE);
				}
				break;
			case IMPORT:
				_localctx = new AlterByImportPartitionContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(3013);
				match(IMPORT);
				setState(3014);
				match(PARTITION);
				setState(3017);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(3015);
					uidList();
					}
					break;
				case ALL:
					{
					setState(3016);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(3019);
				match(TABLESPACE);
				}
				break;
			case TRUNCATE:
				_localctx = new AlterByTruncatePartitionContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(3020);
				match(TRUNCATE);
				setState(3021);
				match(PARTITION);
				setState(3024);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(3022);
					uidList();
					}
					break;
				case ALL:
					{
					setState(3023);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case COALESCE:
				_localctx = new AlterByCoalescePartitionContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(3026);
				match(COALESCE);
				setState(3027);
				match(PARTITION);
				setState(3028);
				decimalLiteral();
				}
				break;
			case REORGANIZE:
				_localctx = new AlterByReorganizePartitionContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(3029);
				match(REORGANIZE);
				setState(3030);
				match(PARTITION);
				setState(3031);
				uidList();
				setState(3032);
				match(INTO);
				setState(3033);
				match(LR_BRACKET);
				setState(3034);
				partitionDefinition();
				setState(3039);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3035);
					match(COMMA);
					setState(3036);
					partitionDefinition();
					}
					}
					setState(3041);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3042);
				match(RR_BRACKET);
				}
				break;
			case EXCHANGE:
				_localctx = new AlterByExchangePartitionContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(3044);
				match(EXCHANGE);
				setState(3045);
				match(PARTITION);
				setState(3046);
				uid();
				setState(3047);
				match(WITH);
				setState(3048);
				match(TABLE);
				setState(3049);
				tableName();
				setState(3052);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH || _la==WITHOUT) {
					{
					setState(3050);
					((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(3051);
					match(VALIDATION);
					}
				}

				}
				break;
			case ANALYZE:
				_localctx = new AlterByAnalyzePartitionContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(3054);
				match(ANALYZE);
				setState(3055);
				match(PARTITION);
				setState(3058);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(3056);
					uidList();
					}
					break;
				case ALL:
					{
					setState(3057);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case CHECK:
				_localctx = new AlterByCheckPartitionContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(3060);
				match(CHECK);
				setState(3061);
				match(PARTITION);
				setState(3064);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(3062);
					uidList();
					}
					break;
				case ALL:
					{
					setState(3063);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case OPTIMIZE:
				_localctx = new AlterByOptimizePartitionContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(3066);
				match(OPTIMIZE);
				setState(3067);
				match(PARTITION);
				setState(3070);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(3068);
					uidList();
					}
					break;
				case ALL:
					{
					setState(3069);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case REBUILD:
				_localctx = new AlterByRebuildPartitionContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(3072);
				match(REBUILD);
				setState(3073);
				match(PARTITION);
				setState(3076);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(3074);
					uidList();
					}
					break;
				case ALL:
					{
					setState(3075);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case REPAIR:
				_localctx = new AlterByRepairPartitionContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(3078);
				match(REPAIR);
				setState(3079);
				match(PARTITION);
				setState(3082);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(3080);
					uidList();
					}
					break;
				case ALL:
					{
					setState(3081);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case REMOVE:
				_localctx = new AlterByRemovePartitioningContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(3084);
				match(REMOVE);
				setState(3085);
				match(PARTITIONING);
				}
				break;
			case UPGRADE:
				_localctx = new AlterByUpgradePartitioningContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(3086);
				match(UPGRADE);
				setState(3087);
				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;
	}

	public static class DropDatabaseContext extends ParserRuleContext {
		public Token dbFormat;
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DATABASE() { return getToken(MariaDBParser.DATABASE, 0); }
		public TerminalNode SCHEMA() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropDatabase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropDatabase(this);
		}
	}

	public final DropDatabaseContext dropDatabase() throws RecognitionException {
		DropDatabaseContext _localctx = new DropDatabaseContext(_ctx, getState());
		enterRule(_localctx, 160, RULE_dropDatabase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3090);
			match(DROP);
			setState(3091);
			((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(3093);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,406,_ctx) ) {
			case 1:
				{
				setState(3092);
				ifExists();
				}
				break;
			}
			setState(3095);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DropEventContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode EVENT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropEvent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropEvent(this);
		}
	}

	public final DropEventContext dropEvent() throws RecognitionException {
		DropEventContext _localctx = new DropEventContext(_ctx, getState());
		enterRule(_localctx, 162, RULE_dropEvent);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3097);
			match(DROP);
			setState(3098);
			match(EVENT);
			setState(3100);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,407,_ctx) ) {
			case 1:
				{
				setState(3099);
				ifExists();
				}
				break;
			}
			setState(3102);
			fullId();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DropIndexContext extends ParserRuleContext {
		public Token intimeAction;
		public Token algType;
		public Token lockType;
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public List ALGORITHM() { return getTokens(MariaDBParser.ALGORITHM); }
		public TerminalNode ALGORITHM(int i) {
			return getToken(MariaDBParser.ALGORITHM, i);
		}
		public List LOCK() { return getTokens(MariaDBParser.LOCK); }
		public TerminalNode LOCK(int i) {
			return getToken(MariaDBParser.LOCK, i);
		}
		public WaitNowaitClauseContext waitNowaitClause() {
			return getRuleContext(WaitNowaitClauseContext.class,0);
		}
		public TerminalNode ONLINE() { return getToken(MariaDBParser.ONLINE, 0); }
		public TerminalNode OFFLINE() { return getToken(MariaDBParser.OFFLINE, 0); }
		public List DEFAULT() { return getTokens(MariaDBParser.DEFAULT); }
		public TerminalNode DEFAULT(int i) {
			return getToken(MariaDBParser.DEFAULT, i);
		}
		public List INPLACE() { return getTokens(MariaDBParser.INPLACE); }
		public TerminalNode INPLACE(int i) {
			return getToken(MariaDBParser.INPLACE, i);
		}
		public List COPY() { return getTokens(MariaDBParser.COPY); }
		public TerminalNode COPY(int i) {
			return getToken(MariaDBParser.COPY, i);
		}
		public List NONE() { return getTokens(MariaDBParser.NONE); }
		public TerminalNode NONE(int i) {
			return getToken(MariaDBParser.NONE, i);
		}
		public List SHARED() { return getTokens(MariaDBParser.SHARED); }
		public TerminalNode SHARED(int i) {
			return getToken(MariaDBParser.SHARED, i);
		}
		public List EXCLUSIVE() { return getTokens(MariaDBParser.EXCLUSIVE); }
		public TerminalNode EXCLUSIVE(int i) {
			return getToken(MariaDBParser.EXCLUSIVE, i);
		}
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropIndex(this);
		}
	}

	public final DropIndexContext dropIndex() throws RecognitionException {
		DropIndexContext _localctx = new DropIndexContext(_ctx, getState());
		enterRule(_localctx, 164, RULE_dropIndex);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(3104);
			match(DROP);
			setState(3105);
			match(INDEX);
			setState(3107);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,408,_ctx) ) {
			case 1:
				{
				setState(3106);
				ifExists();
				}
				break;
			}
			setState(3110);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,409,_ctx) ) {
			case 1:
				{
				setState(3109);
				((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(3112);
			uid();
			setState(3113);
			match(ON);
			setState(3114);
			tableName();
			setState(3127);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,413,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					setState(3125);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case ALGORITHM:
						{
						setState(3115);
						match(ALGORITHM);
						setState(3117);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==EQUAL_SYMBOL) {
							{
							setState(3116);
							match(EQUAL_SYMBOL);
							}
						}

						setState(3119);
						((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(3120);
						match(LOCK);
						setState(3122);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==EQUAL_SYMBOL) {
							{
							setState(3121);
							match(EQUAL_SYMBOL);
							}
						}

						setState(3124);
						((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(3129);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,413,_ctx);
			}
			setState(3131);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOWAIT || _la==WAIT) {
				{
				setState(3130);
				waitNowaitClause();
				}
			}

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

	public static class DropLogfileGroupContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode LOGFILE() { return getToken(MariaDBParser.LOGFILE, 0); }
		public TerminalNode GROUP() { return getToken(MariaDBParser.GROUP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropLogfileGroup(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropLogfileGroup(this);
		}
	}

	public final DropLogfileGroupContext dropLogfileGroup() throws RecognitionException {
		DropLogfileGroupContext _localctx = new DropLogfileGroupContext(_ctx, getState());
		enterRule(_localctx, 166, RULE_dropLogfileGroup);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3133);
			match(DROP);
			setState(3134);
			match(LOGFILE);
			setState(3135);
			match(GROUP);
			setState(3136);
			uid();
			setState(3137);
			match(ENGINE);
			setState(3138);
			match(EQUAL_SYMBOL);
			setState(3139);
			engineName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DropProcedureContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode PROCEDURE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropProcedure(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropProcedure(this);
		}
	}

	public final DropProcedureContext dropProcedure() throws RecognitionException {
		DropProcedureContext _localctx = new DropProcedureContext(_ctx, getState());
		enterRule(_localctx, 168, RULE_dropProcedure);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3141);
			match(DROP);
			setState(3142);
			match(PROCEDURE);
			setState(3144);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,415,_ctx) ) {
			case 1:
				{
				setState(3143);
				ifExists();
				}
				break;
			}
			setState(3146);
			fullId();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DropFunctionContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode FUNCTION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropFunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropFunction(this);
		}
	}

	public final DropFunctionContext dropFunction() throws RecognitionException {
		DropFunctionContext _localctx = new DropFunctionContext(_ctx, getState());
		enterRule(_localctx, 170, RULE_dropFunction);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3148);
			match(DROP);
			setState(3149);
			match(FUNCTION);
			setState(3151);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,416,_ctx) ) {
			case 1:
				{
				setState(3150);
				ifExists();
				}
				break;
			}
			setState(3153);
			fullId();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DropServerContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode SERVER() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropServer(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropServer(this);
		}
	}

	public final DropServerContext dropServer() throws RecognitionException {
		DropServerContext _localctx = new DropServerContext(_ctx, getState());
		enterRule(_localctx, 172, RULE_dropServer);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3155);
			match(DROP);
			setState(3156);
			match(SERVER);
			setState(3158);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,417,_ctx) ) {
			case 1:
				{
				setState(3157);
				ifExists();
				}
				break;
			}
			setState(3160);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DropTableContext extends ParserRuleContext {
		public Token dropType;
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode TEMPORARY() { return getToken(MariaDBParser.TEMPORARY, 0); }
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public WaitNowaitClauseContext waitNowaitClause() {
			return getRuleContext(WaitNowaitClauseContext.class,0);
		}
		public TerminalNode RESTRICT() { return getToken(MariaDBParser.RESTRICT, 0); }
		public TerminalNode CASCADE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropTable(this);
		}
	}

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

			setState(3166);
			match(TABLE);
			setState(3168);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,419,_ctx) ) {
			case 1:
				{
				setState(3167);
				ifExists();
				}
				break;
			}
			setState(3170);
			tables();
			setState(3172);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOWAIT || _la==WAIT) {
				{
				setState(3171);
				waitNowaitClause();
				}
			}

			setState(3175);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CASCADE || _la==RESTRICT) {
				{
				setState(3174);
				((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;
	}

	public static class DropTablespaceContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropTablespace(this);
		}
	}

	public final DropTablespaceContext dropTablespace() throws RecognitionException {
		DropTablespaceContext _localctx = new DropTablespaceContext(_ctx, getState());
		enterRule(_localctx, 176, RULE_dropTablespace);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3177);
			match(DROP);
			setState(3178);
			match(TABLESPACE);
			setState(3179);
			uid();
			setState(3185);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ENGINE) {
				{
				setState(3180);
				match(ENGINE);
				setState(3182);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(3181);
					match(EQUAL_SYMBOL);
					}
				}

				setState(3184);
				engineName();
				}
			}

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

	public static class DropTriggerContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode TRIGGER() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropTrigger(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropTrigger(this);
		}
	}

	public final DropTriggerContext dropTrigger() throws RecognitionException {
		DropTriggerContext _localctx = new DropTriggerContext(_ctx, getState());
		enterRule(_localctx, 178, RULE_dropTrigger);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3187);
			match(DROP);
			setState(3188);
			match(TRIGGER);
			setState(3190);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,424,_ctx) ) {
			case 1:
				{
				setState(3189);
				ifExists();
				}
				break;
			}
			setState(3192);
			fullId();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DropViewContext extends ParserRuleContext {
		public Token dropType;
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode VIEW() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode RESTRICT() { return getToken(MariaDBParser.RESTRICT, 0); }
		public TerminalNode CASCADE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropView(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropView(this);
		}
	}

	public final DropViewContext dropView() throws RecognitionException {
		DropViewContext _localctx = new DropViewContext(_ctx, getState());
		enterRule(_localctx, 180, RULE_dropView);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3194);
			match(DROP);
			setState(3195);
			match(VIEW);
			setState(3197);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,425,_ctx) ) {
			case 1:
				{
				setState(3196);
				ifExists();
				}
				break;
			}
			setState(3199);
			fullId();
			setState(3204);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3200);
				match(COMMA);
				setState(3201);
				fullId();
				}
				}
				setState(3206);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(3208);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CASCADE || _la==RESTRICT) {
				{
				setState(3207);
				((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;
	}

	public static class DropRoleContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode ROLE() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropRole(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropRole(this);
		}
	}

	public final DropRoleContext dropRole() throws RecognitionException {
		DropRoleContext _localctx = new DropRoleContext(_ctx, getState());
		enterRule(_localctx, 182, RULE_dropRole);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3210);
			match(DROP);
			setState(3211);
			match(ROLE);
			setState(3213);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,428,_ctx) ) {
			case 1:
				{
				setState(3212);
				ifExists();
				}
				break;
			}
			setState(3215);
			roleName();
			setState(3220);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3216);
				match(COMMA);
				setState(3217);
				roleName();
				}
				}
				setState(3222);
				_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;
	}

	public static class SetRoleContext extends ParserRuleContext {
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode ROLE() { return getToken(MariaDBParser.ROLE, 0); }
		public TerminalNode TO() { return getToken(MariaDBParser.TO, 0); }
		public TerminalNode NONE() { return getToken(MariaDBParser.NONE, 0); }
		public TerminalNode ALL() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetRole(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetRole(this);
		}
	}

	public final SetRoleContext setRole() throws RecognitionException {
		SetRoleContext _localctx = new SetRoleContext(_ctx, getState());
		enterRule(_localctx, 184, RULE_setRole);
		int _la;
		try {
			setState(3256);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,435,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(3223);
				match(SET);
				setState(3224);
				match(DEFAULT);
				setState(3225);
				match(ROLE);
				setState(3236);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,431,_ctx) ) {
				case 1:
					{
					setState(3226);
					match(NONE);
					}
					break;
				case 2:
					{
					setState(3227);
					match(ALL);
					}
					break;
				case 3:
					{
					setState(3228);
					roleName();
					setState(3233);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(3229);
						match(COMMA);
						setState(3230);
						roleName();
						}
						}
						setState(3235);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
					break;
				}
				setState(3238);
				match(TO);
				setState(3241);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,432,_ctx) ) {
				case 1:
					{
					setState(3239);
					userName();
					}
					break;
				case 2:
					{
					setState(3240);
					uid();
					}
					break;
				}
				setState(3250);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3243);
					match(COMMA);
					setState(3246);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,433,_ctx) ) {
					case 1:
						{
						setState(3244);
						userName();
						}
						break;
					case 2:
						{
						setState(3245);
						uid();
						}
						break;
					}
					}
					}
					setState(3252);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(3253);
				match(SET);
				setState(3254);
				match(ROLE);
				setState(3255);
				roleOption();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DropSequenceContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode SEQUENCE() { return getToken(MariaDBParser.SEQUENCE, 0); }
		public List fullId() {
			return getRuleContexts(FullIdContext.class);
		}
		public FullIdContext fullId(int i) {
			return getRuleContext(FullIdContext.class,i);
		}
		public TerminalNode TEMPORARY() { return getToken(MariaDBParser.TEMPORARY, 0); }
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public TerminalNode COMMENT_INPUT() { return getToken(MariaDBParser.COMMENT_INPUT, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public DropSequenceContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropSequence; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropSequence(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropSequence(this);
		}
	}

	public final DropSequenceContext dropSequence() throws RecognitionException {
		DropSequenceContext _localctx = new DropSequenceContext(_ctx, getState());
		enterRule(_localctx, 186, RULE_dropSequence);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3258);
			match(DROP);
			setState(3260);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==TEMPORARY) {
				{
				setState(3259);
				match(TEMPORARY);
				}
			}

			setState(3262);
			match(SEQUENCE);
			setState(3264);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,437,_ctx) ) {
			case 1:
				{
				setState(3263);
				ifExists();
				}
				break;
			}
			setState(3267);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMENT_INPUT) {
				{
				setState(3266);
				match(COMMENT_INPUT);
				}
			}

			setState(3269);
			fullId();
			setState(3274);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3270);
				match(COMMA);
				setState(3271);
				fullId();
				}
				}
				setState(3276);
				_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;
	}

	public static class RenameTableContext extends ParserRuleContext {
		public TerminalNode RENAME() { return getToken(MariaDBParser.RENAME, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public List renameTableClause() {
			return getRuleContexts(RenameTableClauseContext.class);
		}
		public RenameTableClauseContext renameTableClause(int i) {
			return getRuleContext(RenameTableClauseContext.class,i);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRenameTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRenameTable(this);
		}
	}

	public final RenameTableContext renameTable() throws RecognitionException {
		RenameTableContext _localctx = new RenameTableContext(_ctx, getState());
		enterRule(_localctx, 188, RULE_renameTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3277);
			match(RENAME);
			setState(3278);
			match(TABLE);
			setState(3280);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,440,_ctx) ) {
			case 1:
				{
				setState(3279);
				ifExists();
				}
				break;
			}
			setState(3282);
			renameTableClause();
			setState(3287);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3283);
				match(COMMA);
				setState(3284);
				renameTableClause();
				}
				}
				setState(3289);
				_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;
	}

	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(MariaDBParser.TO, 0); }
		public WaitNowaitClauseContext waitNowaitClause() {
			return getRuleContext(WaitNowaitClauseContext.class,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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRenameTableClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRenameTableClause(this);
		}
	}

	public final RenameTableClauseContext renameTableClause() throws RecognitionException {
		RenameTableClauseContext _localctx = new RenameTableClauseContext(_ctx, getState());
		enterRule(_localctx, 190, RULE_renameTableClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3290);
			tableName();
			setState(3292);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOWAIT || _la==WAIT) {
				{
				setState(3291);
				waitNowaitClause();
				}
			}

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

	public static class TruncateTableContext extends ParserRuleContext {
		public TerminalNode TRUNCATE() { return getToken(MariaDBParser.TRUNCATE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public WaitNowaitClauseContext waitNowaitClause() {
			return getRuleContext(WaitNowaitClauseContext.class,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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTruncateTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTruncateTable(this);
		}
	}

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

			setState(3301);
			tableName();
			setState(3303);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOWAIT || _la==WAIT) {
				{
				setState(3302);
				waitNowaitClause();
				}
			}

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

	public static class CallStatementContext extends ParserRuleContext {
		public TerminalNode CALL() { return getToken(MariaDBParser.CALL, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCallStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCallStatement(this);
		}
	}

	public final CallStatementContext callStatement() throws RecognitionException {
		CallStatementContext _localctx = new CallStatementContext(_ctx, getState());
		enterRule(_localctx, 194, RULE_callStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3305);
			match(CALL);
			setState(3306);
			fullId();
			setState(3313);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,446,_ctx) ) {
			case 1:
				{
				setState(3307);
				match(LR_BRACKET);
				setState(3310);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,445,_ctx) ) {
				case 1:
					{
					setState(3308);
					constants();
					}
					break;
				case 2:
					{
					setState(3309);
					expressions();
					}
					break;
				}
				setState(3312);
				match(RR_BRACKET);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDeleteStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDeleteStatement(this);
		}
	}

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

	public static class DoStatementContext extends ParserRuleContext {
		public TerminalNode DO() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDoStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDoStatement(this);
		}
	}

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

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerStatement(this);
		}
	}

	public final HandlerStatementContext handlerStatement() throws RecognitionException {
		HandlerStatementContext _localctx = new HandlerStatementContext(_ctx, getState());
		enterRule(_localctx, 200, RULE_handlerStatement);
		try {
			setState(3326);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,448,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(3322);
				handlerOpenStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(3323);
				handlerReadIndexStatement();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(3324);
				handlerReadStatement();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(3325);
				handlerCloseStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class InsertStatementContext extends ParserRuleContext {
		public Token priority;
		public UidListContext partitions;
		public UidListContext 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(MariaDBParser.INSERT, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public InsertStatementValueContext insertStatementValue() {
			return getRuleContext(InsertStatementValueContext.class,0);
		}
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode IGNORE() { return getToken(MariaDBParser.IGNORE, 0); }
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.ON, 0); }
		public TerminalNode DUPLICATE() { return getToken(MariaDBParser.DUPLICATE, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public TerminalNode UPDATE() { return getToken(MariaDBParser.UPDATE, 0); }
		public TerminalNode LOW_PRIORITY() { return getToken(MariaDBParser.LOW_PRIORITY, 0); }
		public TerminalNode DELAYED() { return getToken(MariaDBParser.DELAYED, 0); }
		public TerminalNode HIGH_PRIORITY() { return getToken(MariaDBParser.HIGH_PRIORITY, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public List uidList() {
			return getRuleContexts(UidListContext.class);
		}
		public UidListContext uidList(int i) {
			return getRuleContext(UidListContext.class,i);
		}
		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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterInsertStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitInsertStatement(this);
		}
	}

	public final InsertStatementContext insertStatement() throws RecognitionException {
		InsertStatementContext _localctx = new InsertStatementContext(_ctx, getState());
		enterRule(_localctx, 202, RULE_insertStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3328);
			match(INSERT);
			setState(3330);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (((((_la - 44)) & ~0x3f) == 0 && ((1L << (_la - 44)) & ((1L << (DELAYED - 44)) | (1L << (HIGH_PRIORITY - 44)) | (1L << (LOW_PRIORITY - 44)))) != 0)) {
				{
				setState(3329);
				((InsertStatementContext)_localctx).priority = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 44)) & ~0x3f) == 0 && ((1L << (_la - 44)) & ((1L << (DELAYED - 44)) | (1L << (HIGH_PRIORITY - 44)) | (1L << (LOW_PRIORITY - 44)))) != 0)) ) {
					((InsertStatementContext)_localctx).priority = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

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

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

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

				setState(3344);
				match(RR_BRACKET);
				}
			}

			setState(3363);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SELECT:
			case VALUES:
			case VALUE:
			case LR_BRACKET:
				{
				setState(3351);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,454,_ctx) ) {
				case 1:
					{
					setState(3347);
					match(LR_BRACKET);
					setState(3348);
					((InsertStatementContext)_localctx).columns = uidList();
					setState(3349);
					match(RR_BRACKET);
					}
					break;
				}
				setState(3353);
				insertStatementValue();
				}
				break;
			case SET:
				{
				setState(3354);
				match(SET);
				setState(3355);
				((InsertStatementContext)_localctx).setFirst = updatedElement();
				setState(3360);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3356);
					match(COMMA);
					setState(3357);
					((InsertStatementContext)_localctx).updatedElement = updatedElement();
					((InsertStatementContext)_localctx).setElements.add(((InsertStatementContext)_localctx).updatedElement);
					}
					}
					setState(3362);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(3377);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ON) {
				{
				setState(3365);
				match(ON);
				setState(3366);
				match(DUPLICATE);
				setState(3367);
				match(KEY);
				setState(3368);
				match(UPDATE);
				setState(3369);
				((InsertStatementContext)_localctx).duplicatedFirst = updatedElement();
				setState(3374);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3370);
					match(COMMA);
					setState(3371);
					((InsertStatementContext)_localctx).updatedElement = updatedElement();
					((InsertStatementContext)_localctx).duplicatedElements.add(((InsertStatementContext)_localctx).updatedElement);
					}
					}
					setState(3376);
					_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;
	}

	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(MariaDBParser.LOAD, 0); }
		public TerminalNode DATA() { return getToken(MariaDBParser.DATA, 0); }
		public TerminalNode INFILE() { return getToken(MariaDBParser.INFILE, 0); }
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode LOCAL() { return getToken(MariaDBParser.LOCAL, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.LR_BRACKET, i);
		}
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public List RR_BRACKET() { return getTokens(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.RR_BRACKET, i);
		}
		public TerminalNode CHARACTER() { return getToken(MariaDBParser.CHARACTER, 0); }
		public List SET() { return getTokens(MariaDBParser.SET); }
		public TerminalNode SET(int i) {
			return getToken(MariaDBParser.SET, i);
		}
		public List LINES() { return getTokens(MariaDBParser.LINES); }
		public TerminalNode LINES(int i) {
			return getToken(MariaDBParser.LINES, i);
		}
		public List IGNORE() { return getTokens(MariaDBParser.IGNORE); }
		public TerminalNode IGNORE(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.LOW_PRIORITY, 0); }
		public TerminalNode CONCURRENT() { return getToken(MariaDBParser.CONCURRENT, 0); }
		public TerminalNode REPLACE() { return getToken(MariaDBParser.REPLACE, 0); }
		public TerminalNode FIELDS() { return getToken(MariaDBParser.FIELDS, 0); }
		public TerminalNode COLUMNS() { return getToken(MariaDBParser.COLUMNS, 0); }
		public TerminalNode ROWS() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLoadDataStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLoadDataStatement(this);
		}
	}

	public final LoadDataStatementContext loadDataStatement() throws RecognitionException {
		LoadDataStatementContext _localctx = new LoadDataStatementContext(_ctx, getState());
		enterRule(_localctx, 204, RULE_loadDataStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3379);
			match(LOAD);
			setState(3380);
			match(DATA);
			setState(3382);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOW_PRIORITY || _la==CONCURRENT) {
				{
				setState(3381);
				((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(3385);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL) {
				{
				setState(3384);
				match(LOCAL);
				}
			}

			setState(3387);
			match(INFILE);
			setState(3388);
			((LoadDataStatementContext)_localctx).filename = match(STRING_LITERAL);
			setState(3390);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE || _la==REPLACE) {
				{
				setState(3389);
				((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(3392);
			match(INTO);
			setState(3393);
			match(TABLE);
			setState(3394);
			tableName();
			setState(3400);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(3395);
				match(PARTITION);
				setState(3396);
				match(LR_BRACKET);
				setState(3397);
				uidList();
				setState(3398);
				match(RR_BRACKET);
				}
			}

			setState(3405);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CHARACTER) {
				{
				setState(3402);
				match(CHARACTER);
				setState(3403);
				match(SET);
				setState(3404);
				((LoadDataStatementContext)_localctx).charset = charsetName();
				}
			}

			setState(3413);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COLUMNS || _la==FIELDS) {
				{
				setState(3407);
				((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(3409); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(3408);
					selectFieldsInto();
					}
					}
					setState(3411); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==ENCLOSED || _la==ESCAPED || _la==OPTIONALLY || _la==TERMINATED );
				}
			}

			setState(3421);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LINES) {
				{
				setState(3415);
				match(LINES);
				setState(3417); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(3416);
					selectLinesInto();
					}
					}
					setState(3419); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==STARTING || _la==TERMINATED );
				}
			}

			setState(3427);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(3423);
				match(IGNORE);
				setState(3424);
				decimalLiteral();
				setState(3425);
				((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(3440);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,470,_ctx) ) {
			case 1:
				{
				setState(3429);
				match(LR_BRACKET);
				setState(3430);
				assignmentField();
				setState(3435);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3431);
					match(COMMA);
					setState(3432);
					assignmentField();
					}
					}
					setState(3437);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3438);
				match(RR_BRACKET);
				}
				break;
			}
			setState(3451);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,472,_ctx) ) {
			case 1:
				{
				setState(3442);
				match(SET);
				setState(3443);
				updatedElement();
				setState(3448);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3444);
					match(COMMA);
					setState(3445);
					updatedElement();
					}
					}
					setState(3450);
					_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;
	}

	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(MariaDBParser.LOAD, 0); }
		public TerminalNode XML() { return getToken(MariaDBParser.XML, 0); }
		public TerminalNode INFILE() { return getToken(MariaDBParser.INFILE, 0); }
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public List STRING_LITERAL() { return getTokens(MariaDBParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MariaDBParser.STRING_LITERAL, i);
		}
		public TerminalNode LOCAL() { return getToken(MariaDBParser.LOCAL, 0); }
		public TerminalNode CHARACTER() { return getToken(MariaDBParser.CHARACTER, 0); }
		public List SET() { return getTokens(MariaDBParser.SET); }
		public TerminalNode SET(int i) {
			return getToken(MariaDBParser.SET, i);
		}
		public List ROWS() { return getTokens(MariaDBParser.ROWS); }
		public TerminalNode ROWS(int i) {
			return getToken(MariaDBParser.ROWS, i);
		}
		public TerminalNode IDENTIFIED() { return getToken(MariaDBParser.IDENTIFIED, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public TerminalNode LESS_SYMBOL() { return getToken(MariaDBParser.LESS_SYMBOL, 0); }
		public TerminalNode GREATER_SYMBOL() { return getToken(MariaDBParser.GREATER_SYMBOL, 0); }
		public List IGNORE() { return getTokens(MariaDBParser.IGNORE); }
		public TerminalNode IGNORE(int i) {
			return getToken(MariaDBParser.IGNORE, i);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.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(MariaDBParser.LOW_PRIORITY, 0); }
		public TerminalNode CONCURRENT() { return getToken(MariaDBParser.CONCURRENT, 0); }
		public TerminalNode REPLACE() { return getToken(MariaDBParser.REPLACE, 0); }
		public TerminalNode LINES() { return getToken(MariaDBParser.LINES, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLoadXmlStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLoadXmlStatement(this);
		}
	}

	public final LoadXmlStatementContext loadXmlStatement() throws RecognitionException {
		LoadXmlStatementContext _localctx = new LoadXmlStatementContext(_ctx, getState());
		enterRule(_localctx, 206, RULE_loadXmlStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3453);
			match(LOAD);
			setState(3454);
			match(XML);
			setState(3456);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOW_PRIORITY || _la==CONCURRENT) {
				{
				setState(3455);
				((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(3459);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL) {
				{
				setState(3458);
				match(LOCAL);
				}
			}

			setState(3461);
			match(INFILE);
			setState(3462);
			((LoadXmlStatementContext)_localctx).filename = match(STRING_LITERAL);
			setState(3464);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE || _la==REPLACE) {
				{
				setState(3463);
				((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(3466);
			match(INTO);
			setState(3467);
			match(TABLE);
			setState(3468);
			tableName();
			setState(3472);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CHARACTER) {
				{
				setState(3469);
				match(CHARACTER);
				setState(3470);
				match(SET);
				setState(3471);
				((LoadXmlStatementContext)_localctx).charset = charsetName();
				}
			}

			setState(3480);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ROWS) {
				{
				setState(3474);
				match(ROWS);
				setState(3475);
				match(IDENTIFIED);
				setState(3476);
				match(BY);
				setState(3477);
				match(LESS_SYMBOL);
				setState(3478);
				((LoadXmlStatementContext)_localctx).tag = match(STRING_LITERAL);
				setState(3479);
				match(GREATER_SYMBOL);
				}
			}

			setState(3486);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(3482);
				match(IGNORE);
				setState(3483);
				decimalLiteral();
				setState(3484);
				((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(3499);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,480,_ctx) ) {
			case 1:
				{
				setState(3488);
				match(LR_BRACKET);
				setState(3489);
				assignmentField();
				setState(3494);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3490);
					match(COMMA);
					setState(3491);
					assignmentField();
					}
					}
					setState(3496);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3497);
				match(RR_BRACKET);
				}
				break;
			}
			setState(3510);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,482,_ctx) ) {
			case 1:
				{
				setState(3501);
				match(SET);
				setState(3502);
				updatedElement();
				setState(3507);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3503);
					match(COMMA);
					setState(3504);
					updatedElement();
					}
					}
					setState(3509);
					_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;
	}

	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(MariaDBParser.REPLACE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public InsertStatementValueContext insertStatementValue() {
			return getRuleContext(InsertStatementValueContext.class,0);
		}
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.LOW_PRIORITY, 0); }
		public TerminalNode DELAYED() { return getToken(MariaDBParser.DELAYED, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterReplaceStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitReplaceStatement(this);
		}
	}

	public final ReplaceStatementContext replaceStatement() throws RecognitionException {
		ReplaceStatementContext _localctx = new ReplaceStatementContext(_ctx, getState());
		enterRule(_localctx, 208, RULE_replaceStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3512);
			match(REPLACE);
			setState(3514);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DELAYED || _la==LOW_PRIORITY) {
				{
				setState(3513);
				((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(3517);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INTO) {
				{
				setState(3516);
				match(INTO);
				}
			}

			setState(3519);
			tableName();
			setState(3525);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(3520);
				match(PARTITION);
				setState(3521);
				match(LR_BRACKET);
				setState(3522);
				((ReplaceStatementContext)_localctx).partitions = uidList();
				setState(3523);
				match(RR_BRACKET);
				}
			}

			setState(3543);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SELECT:
			case VALUES:
			case VALUE:
			case LR_BRACKET:
				{
				setState(3531);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,486,_ctx) ) {
				case 1:
					{
					setState(3527);
					match(LR_BRACKET);
					setState(3528);
					((ReplaceStatementContext)_localctx).columns = uidList();
					setState(3529);
					match(RR_BRACKET);
					}
					break;
				}
				setState(3533);
				insertStatementValue();
				}
				break;
			case SET:
				{
				setState(3534);
				match(SET);
				setState(3535);
				((ReplaceStatementContext)_localctx).setFirst = updatedElement();
				setState(3540);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3536);
					match(COMMA);
					setState(3537);
					((ReplaceStatementContext)_localctx).updatedElement = updatedElement();
					((ReplaceStatementContext)_localctx).setElements.add(((ReplaceStatementContext)_localctx).updatedElement);
					}
					}
					setState(3542);
					_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;
	}

	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);
		}
	}
	public static class UnionSelectContext extends SelectStatementContext {
		public Token unionType;
		public QuerySpecificationNointoContext querySpecificationNointo() {
			return getRuleContext(QuerySpecificationNointoContext.class,0);
		}
		public List unionStatement() {
			return getRuleContexts(UnionStatementContext.class);
		}
		public UnionStatementContext unionStatement(int i) {
			return getRuleContext(UnionStatementContext.class,i);
		}
		public TerminalNode UNION() { return getToken(MariaDBParser.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(MariaDBParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MariaDBParser.DISTINCT, 0); }
		public UnionSelectContext(SelectStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterUnionSelect(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUnionSelect(this);
		}
	}
	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(MariaDBParser.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(MariaDBParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MariaDBParser.DISTINCT, 0); }
		public UnionParenthesisSelectContext(SelectStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterUnionParenthesisSelect(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUnionParenthesisSelect(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSimpleSelect(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSimpleSelect(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterParenthesisSelect(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitParenthesisSelect(this);
		}
	}
	public static class WithLateralStatementContext extends SelectStatementContext {
		public QuerySpecificationNointoContext querySpecificationNointo() {
			return getRuleContext(QuerySpecificationNointoContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterWithLateralStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitWithLateralStatement(this);
		}
	}

	public final SelectStatementContext selectStatement() throws RecognitionException {
		SelectStatementContext _localctx = new SelectStatementContext(_ctx, getState());
		enterRule(_localctx, 210, RULE_selectStatement);
		int _la;
		try {
			int _alt;
			setState(3607);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,505,_ctx) ) {
			case 1:
				_localctx = new SimpleSelectContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(3545);
				querySpecification();
				setState(3547);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,489,_ctx) ) {
				case 1:
					{
					setState(3546);
					lockClause();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new ParenthesisSelectContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(3549);
				queryExpression();
				setState(3551);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,490,_ctx) ) {
				case 1:
					{
					setState(3550);
					lockClause();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new UnionSelectContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(3553);
				querySpecificationNointo();
				setState(3555); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(3554);
						unionStatement();
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(3557); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,491,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(3567);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==UNION) {
					{
					setState(3559);
					match(UNION);
					setState(3561);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==ALL || _la==DISTINCT) {
						{
						setState(3560);
						((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(3565);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case SELECT:
						{
						setState(3563);
						querySpecification();
						}
						break;
					case LR_BRACKET:
						{
						setState(3564);
						queryExpression();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
				}

				setState(3570);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,495,_ctx) ) {
				case 1:
					{
					setState(3569);
					orderByClause();
					}
					break;
				}
				setState(3573);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIMIT) {
					{
					setState(3572);
					limitClause();
					}
				}

				setState(3576);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,497,_ctx) ) {
				case 1:
					{
					setState(3575);
					lockClause();
					}
					break;
				}
				}
				break;
			case 4:
				_localctx = new UnionParenthesisSelectContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(3578);
				queryExpressionNointo();
				setState(3580); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(3579);
						unionParenthesis();
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(3582); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,498,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(3589);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==UNION) {
					{
					setState(3584);
					match(UNION);
					setState(3586);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==ALL || _la==DISTINCT) {
						{
						setState(3585);
						((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(3588);
					queryExpression();
					}
				}

				setState(3592);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,501,_ctx) ) {
				case 1:
					{
					setState(3591);
					orderByClause();
					}
					break;
				}
				setState(3595);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIMIT) {
					{
					setState(3594);
					limitClause();
					}
				}

				setState(3598);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,503,_ctx) ) {
				case 1:
					{
					setState(3597);
					lockClause();
					}
					break;
				}
				}
				break;
			case 5:
				_localctx = new WithLateralStatementContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(3600);
				querySpecificationNointo();
				setState(3603); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(3601);
					match(COMMA);
					setState(3602);
					lateralStatement();
					}
					}
					setState(3605); 
					_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;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUpdateStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUpdateStatement(this);
		}
	}

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

	public static class ValuesStatementContext extends ParserRuleContext {
		public TerminalNode VALUES() { return getToken(MariaDBParser.VALUES, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterValuesStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitValuesStatement(this);
		}
	}

	public final ValuesStatementContext valuesStatement() throws RecognitionException {
		ValuesStatementContext _localctx = new ValuesStatementContext(_ctx, getState());
		enterRule(_localctx, 214, RULE_valuesStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3613);
			match(VALUES);
			setState(3614);
			match(LR_BRACKET);
			setState(3616);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,507,_ctx) ) {
			case 1:
				{
				setState(3615);
				expressionsWithDefaults();
				}
				break;
			}
			setState(3618);
			match(RR_BRACKET);
			setState(3627);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3619);
				match(COMMA);
				setState(3620);
				match(LR_BRACKET);
				setState(3622);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,508,_ctx) ) {
				case 1:
					{
					setState(3621);
					expressionsWithDefaults();
					}
					break;
				}
				setState(3624);
				match(RR_BRACKET);
				}
				}
				setState(3629);
				_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;
	}

	public static class InsertStatementValueContext extends ParserRuleContext {
		public Token insertFormat;
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.RR_BRACKET, i);
		}
		public TerminalNode VALUES() { return getToken(MariaDBParser.VALUES, 0); }
		public TerminalNode VALUE() { return getToken(MariaDBParser.VALUE, 0); }
		public List expressionsWithDefaults() {
			return getRuleContexts(ExpressionsWithDefaultsContext.class);
		}
		public ExpressionsWithDefaultsContext expressionsWithDefaults(int i) {
			return getRuleContext(ExpressionsWithDefaultsContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterInsertStatementValue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitInsertStatementValue(this);
		}
	}

	public final InsertStatementValueContext insertStatementValue() throws RecognitionException {
		InsertStatementValueContext _localctx = new InsertStatementValueContext(_ctx, getState());
		enterRule(_localctx, 216, RULE_insertStatementValue);
		int _la;
		try {
			setState(3648);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SELECT:
			case LR_BRACKET:
				enterOuterAlt(_localctx, 1);
				{
				setState(3630);
				selectStatement();
				}
				break;
			case VALUES:
			case VALUE:
				enterOuterAlt(_localctx, 2);
				{
				setState(3631);
				((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(3632);
				match(LR_BRACKET);
				setState(3634);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,510,_ctx) ) {
				case 1:
					{
					setState(3633);
					expressionsWithDefaults();
					}
					break;
				}
				setState(3636);
				match(RR_BRACKET);
				setState(3645);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3637);
					match(COMMA);
					setState(3638);
					match(LR_BRACKET);
					setState(3640);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,511,_ctx) ) {
					case 1:
						{
						setState(3639);
						expressionsWithDefaults();
						}
						break;
					}
					setState(3642);
					match(RR_BRACKET);
					}
					}
					setState(3647);
					_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;
	}

	public static class UpdatedElementContext extends ParserRuleContext {
		public FullColumnNameContext fullColumnName() {
			return getRuleContext(FullColumnNameContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUpdatedElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUpdatedElement(this);
		}
	}

	public final UpdatedElementContext updatedElement() throws RecognitionException {
		UpdatedElementContext _localctx = new UpdatedElementContext(_ctx, getState());
		enterRule(_localctx, 218, RULE_updatedElement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3650);
			fullColumnName();
			setState(3651);
			match(EQUAL_SYMBOL);
			setState(3654);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,514,_ctx) ) {
			case 1:
				{
				setState(3652);
				expression(0);
				}
				break;
			case 2:
				{
				setState(3653);
				match(DEFAULT);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class AssignmentFieldContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode LOCAL_ID() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAssignmentField(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAssignmentField(this);
		}
	}

	public final AssignmentFieldContext assignmentField() throws RecognitionException {
		AssignmentFieldContext _localctx = new AssignmentFieldContext(_ctx, getState());
		enterRule(_localctx, 220, RULE_assignmentField);
		try {
			setState(3658);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ATTRIBUTE:
			case BODY:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_ROLE:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case LOCKED:
			case MAXVALUE:
			case MINVALUE:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case PACKAGE:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_:
			case STACKED:
			case STATEMENT:
			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 CYCLE:
			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 ENCRYPTED:
			case ENCRYPTION:
			case ENCRYPTION_KEY_ID:
			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 INCREMENT:
			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 LOCALES:
			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 NOCACHE:
			case NOCOPY:
			case NOCYCLE:
			case NOMAXVALUE:
			case NOMINVALUE:
			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 QUERY_RESPONSE_TIME:
			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 RESTART:
			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 SEQUENCE:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLAVES:
			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 TYPES:
			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 WSREP_MEMBERSHIP:
			case WSREP_STATUS:
			case X509:
			case XA:
			case XML:
			case YES:
			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 USER_STATISTICS:
			case CLIENT_STATISTICS:
			case INDEX_STATISTICS:
			case TABLE_STATISTICS:
			case ADMIN:
			case AUDIT_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_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_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 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 VIA:
			case LASTVAL:
			case NEXTVAL:
			case SETVAL:
			case PREVIOUS:
			case PERSISTENT:
			case BINLOG_MONITOR:
			case BINLOG_REPLAY:
			case FEDERATED_ADMIN:
			case READ_ONLY_ADMIN:
			case REPLICA:
			case REPLICAS:
			case REPLICATION_MASTER_ADMIN:
			case MONITOR:
			case READ_ONLY:
			case REPLAY:
			case MOD:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				enterOuterAlt(_localctx, 1);
				{
				setState(3656);
				uid();
				}
				break;
			case LOCAL_ID:
				enterOuterAlt(_localctx, 2);
				{
				setState(3657);
				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;
	}

	public static class LockClauseContext extends ParserRuleContext {
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode UPDATE() { return getToken(MariaDBParser.UPDATE, 0); }
		public TerminalNode LOCK() { return getToken(MariaDBParser.LOCK, 0); }
		public TerminalNode IN() { return getToken(MariaDBParser.IN, 0); }
		public TerminalNode SHARE() { return getToken(MariaDBParser.SHARE, 0); }
		public TerminalNode MODE() { return getToken(MariaDBParser.MODE, 0); }
		public LockOptionContext lockOption() {
			return getRuleContext(LockOptionContext.class,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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLockClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLockClause(this);
		}
	}

	public final LockClauseContext lockClause() throws RecognitionException {
		LockClauseContext _localctx = new LockClauseContext(_ctx, getState());
		enterRule(_localctx, 222, RULE_lockClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3666);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case FOR:
				{
				setState(3660);
				match(FOR);
				setState(3661);
				match(UPDATE);
				}
				break;
			case LOCK:
				{
				setState(3662);
				match(LOCK);
				setState(3663);
				match(IN);
				setState(3664);
				match(SHARE);
				setState(3665);
				match(MODE);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(3669);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,517,_ctx) ) {
			case 1:
				{
				setState(3668);
				lockOption();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class SingleDeleteStatementContext extends ParserRuleContext {
		public Token priority;
		public TerminalNode DELETE() { return getToken(MariaDBParser.DELETE, 0); }
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode QUICK() { return getToken(MariaDBParser.QUICK, 0); }
		public TerminalNode IGNORE() { return getToken(MariaDBParser.IGNORE, 0); }
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode WHERE() { return getToken(MariaDBParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public OrderByClauseContext orderByClause() {
			return getRuleContext(OrderByClauseContext.class,0);
		}
		public TerminalNode LIMIT() { return getToken(MariaDBParser.LIMIT, 0); }
		public LimitClauseAtomContext limitClauseAtom() {
			return getRuleContext(LimitClauseAtomContext.class,0);
		}
		public TerminalNode LOW_PRIORITY() { return getToken(MariaDBParser.LOW_PRIORITY, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSingleDeleteStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSingleDeleteStatement(this);
		}
	}

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

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

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

			setState(3681);
			match(FROM);
			setState(3682);
			tableName();
			setState(3688);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(3683);
				match(PARTITION);
				setState(3684);
				match(LR_BRACKET);
				setState(3685);
				uidList();
				setState(3686);
				match(RR_BRACKET);
				}
			}

			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(3699);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LIMIT) {
				{
				setState(3697);
				match(LIMIT);
				setState(3698);
				limitClauseAtom();
				}
			}

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

	public static class MultipleDeleteStatementContext extends ParserRuleContext {
		public Token priority;
		public TerminalNode DELETE() { return getToken(MariaDBParser.DELETE, 0); }
		public List tableName() {
			return getRuleContexts(TableNameContext.class);
		}
		public TableNameContext tableName(int i) {
			return getRuleContext(TableNameContext.class,i);
		}
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public TableSourcesContext tableSources() {
			return getRuleContext(TableSourcesContext.class,0);
		}
		public TerminalNode USING() { return getToken(MariaDBParser.USING, 0); }
		public TerminalNode QUICK() { return getToken(MariaDBParser.QUICK, 0); }
		public TerminalNode IGNORE() { return getToken(MariaDBParser.IGNORE, 0); }
		public TerminalNode WHERE() { return getToken(MariaDBParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode LOW_PRIORITY() { return getToken(MariaDBParser.LOW_PRIORITY, 0); }
		public List DOT() { return getTokens(MariaDBParser.DOT); }
		public TerminalNode DOT(int i) {
			return getToken(MariaDBParser.DOT, i);
		}
		public List STAR() { return getTokens(MariaDBParser.STAR); }
		public TerminalNode STAR(int i) {
			return getToken(MariaDBParser.STAR, i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterMultipleDeleteStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMultipleDeleteStatement(this);
		}
	}

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

			setState(3706);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,526,_ctx) ) {
			case 1:
				{
				setState(3705);
				match(QUICK);
				}
				break;
			}
			setState(3709);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(3708);
				match(IGNORE);
				}
			}

			setState(3750);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ATTRIBUTE:
			case BODY:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_ROLE:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case LOCKED:
			case MAXVALUE:
			case MINVALUE:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case PACKAGE:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_:
			case STACKED:
			case STATEMENT:
			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 CYCLE:
			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 ENCRYPTED:
			case ENCRYPTION:
			case ENCRYPTION_KEY_ID:
			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 INCREMENT:
			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 LOCALES:
			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 NOCACHE:
			case NOCOPY:
			case NOCYCLE:
			case NOMAXVALUE:
			case NOMINVALUE:
			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 QUERY_RESPONSE_TIME:
			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 RESTART:
			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 SEQUENCE:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLAVES:
			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 TYPES:
			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 WSREP_MEMBERSHIP:
			case WSREP_STATUS:
			case X509:
			case XA:
			case XML:
			case YES:
			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 USER_STATISTICS:
			case CLIENT_STATISTICS:
			case INDEX_STATISTICS:
			case TABLE_STATISTICS:
			case ADMIN:
			case AUDIT_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_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_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 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 VIA:
			case LASTVAL:
			case NEXTVAL:
			case SETVAL:
			case PREVIOUS:
			case PERSISTENT:
			case BINLOG_MONITOR:
			case BINLOG_REPLAY:
			case FEDERATED_ADMIN:
			case READ_ONLY_ADMIN:
			case REPLICA:
			case REPLICAS:
			case REPLICATION_MASTER_ADMIN:
			case MONITOR:
			case READ_ONLY:
			case REPLAY:
			case MOD:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				{
				setState(3711);
				tableName();
				setState(3714);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DOT) {
					{
					setState(3712);
					match(DOT);
					setState(3713);
					match(STAR);
					}
				}

				setState(3724);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3716);
					match(COMMA);
					setState(3717);
					tableName();
					setState(3720);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==DOT) {
						{
						setState(3718);
						match(DOT);
						setState(3719);
						match(STAR);
						}
					}

					}
					}
					setState(3726);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3727);
				match(FROM);
				setState(3728);
				tableSources();
				}
				break;
			case FROM:
				{
				setState(3730);
				match(FROM);
				setState(3731);
				tableName();
				setState(3734);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DOT) {
					{
					setState(3732);
					match(DOT);
					setState(3733);
					match(STAR);
					}
				}

				setState(3744);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3736);
					match(COMMA);
					setState(3737);
					tableName();
					setState(3740);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==DOT) {
						{
						setState(3738);
						match(DOT);
						setState(3739);
						match(STAR);
						}
					}

					}
					}
					setState(3746);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3747);
				match(USING);
				setState(3748);
				tableSources();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(3754);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3752);
				match(WHERE);
				setState(3753);
				expression(0);
				}
			}

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

	public static class HandlerOpenStatementContext extends ParserRuleContext {
		public TerminalNode HANDLER() { return getToken(MariaDBParser.HANDLER, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode OPEN() { return getToken(MariaDBParser.OPEN, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerOpenStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerOpenStatement(this);
		}
	}

	public final HandlerOpenStatementContext handlerOpenStatement() throws RecognitionException {
		HandlerOpenStatementContext _localctx = new HandlerOpenStatementContext(_ctx, getState());
		enterRule(_localctx, 228, RULE_handlerOpenStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3756);
			match(HANDLER);
			setState(3757);
			tableName();
			setState(3758);
			match(OPEN);
			setState(3763);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,537,_ctx) ) {
			case 1:
				{
				setState(3760);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(3759);
					match(AS);
					}
				}

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

	public static class HandlerReadIndexStatementContext extends ParserRuleContext {
		public UidContext index;
		public Token moveOrder;
		public TerminalNode HANDLER() { return getToken(MariaDBParser.HANDLER, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode READ() { return getToken(MariaDBParser.READ, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public ComparisonOperatorContext comparisonOperator() {
			return getRuleContext(ComparisonOperatorContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ConstantsContext constants() {
			return getRuleContext(ConstantsContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode WHERE() { return getToken(MariaDBParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode LIMIT() { return getToken(MariaDBParser.LIMIT, 0); }
		public LimitClauseAtomContext limitClauseAtom() {
			return getRuleContext(LimitClauseAtomContext.class,0);
		}
		public TerminalNode FIRST() { return getToken(MariaDBParser.FIRST, 0); }
		public TerminalNode NEXT() { return getToken(MariaDBParser.NEXT, 0); }
		public TerminalNode PREV() { return getToken(MariaDBParser.PREV, 0); }
		public TerminalNode LAST() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerReadIndexStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerReadIndexStatement(this);
		}
	}

	public final HandlerReadIndexStatementContext handlerReadIndexStatement() throws RecognitionException {
		HandlerReadIndexStatementContext _localctx = new HandlerReadIndexStatementContext(_ctx, getState());
		enterRule(_localctx, 230, RULE_handlerReadIndexStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3765);
			match(HANDLER);
			setState(3766);
			tableName();
			setState(3767);
			match(READ);
			setState(3768);
			((HandlerReadIndexStatementContext)_localctx).index = uid();
			setState(3775);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case EQUAL_SYMBOL:
			case GREATER_SYMBOL:
			case LESS_SYMBOL:
			case EXCLAMATION_SYMBOL:
				{
				setState(3769);
				comparisonOperator();
				setState(3770);
				match(LR_BRACKET);
				setState(3771);
				constants();
				setState(3772);
				match(RR_BRACKET);
				}
				break;
			case FIRST:
			case LAST:
			case NEXT:
			case PREV:
				{
				setState(3774);
				((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(3779);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3777);
				match(WHERE);
				setState(3778);
				expression(0);
				}
			}

			setState(3783);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LIMIT) {
				{
				setState(3781);
				match(LIMIT);
				setState(3782);
				limitClauseAtom();
				}
			}

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

	public static class HandlerReadStatementContext extends ParserRuleContext {
		public Token moveOrder;
		public TerminalNode HANDLER() { return getToken(MariaDBParser.HANDLER, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode READ() { return getToken(MariaDBParser.READ, 0); }
		public TerminalNode FIRST() { return getToken(MariaDBParser.FIRST, 0); }
		public TerminalNode NEXT() { return getToken(MariaDBParser.NEXT, 0); }
		public TerminalNode WHERE() { return getToken(MariaDBParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode LIMIT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerReadStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerReadStatement(this);
		}
	}

	public final HandlerReadStatementContext handlerReadStatement() throws RecognitionException {
		HandlerReadStatementContext _localctx = new HandlerReadStatementContext(_ctx, getState());
		enterRule(_localctx, 232, RULE_handlerReadStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3785);
			match(HANDLER);
			setState(3786);
			tableName();
			setState(3787);
			match(READ);
			setState(3788);
			((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(3791);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3789);
				match(WHERE);
				setState(3790);
				expression(0);
				}
			}

			setState(3795);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LIMIT) {
				{
				setState(3793);
				match(LIMIT);
				setState(3794);
				limitClauseAtom();
				}
			}

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

	public static class HandlerCloseStatementContext extends ParserRuleContext {
		public TerminalNode HANDLER() { return getToken(MariaDBParser.HANDLER, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode CLOSE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerCloseStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerCloseStatement(this);
		}
	}

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

	public static class SingleUpdateStatementContext extends ParserRuleContext {
		public Token priority;
		public TerminalNode UPDATE() { return getToken(MariaDBParser.UPDATE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public List updatedElement() {
			return getRuleContexts(UpdatedElementContext.class);
		}
		public UpdatedElementContext updatedElement(int i) {
			return getRuleContext(UpdatedElementContext.class,i);
		}
		public TerminalNode IGNORE() { return getToken(MariaDBParser.IGNORE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode WHERE() { return getToken(MariaDBParser.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(MariaDBParser.LOW_PRIORITY, 0); }
		public TerminalNode AS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSingleUpdateStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSingleUpdateStatement(this);
		}
	}

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

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

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

				setState(3812);
				uid();
				}
			}

			setState(3815);
			match(SET);
			setState(3816);
			updatedElement();
			setState(3821);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3817);
				match(COMMA);
				setState(3818);
				updatedElement();
				}
				}
				setState(3823);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(3826);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3824);
				match(WHERE);
				setState(3825);
				expression(0);
				}
			}

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

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

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

	public static class MultipleUpdateStatementContext extends ParserRuleContext {
		public Token priority;
		public TerminalNode UPDATE() { return getToken(MariaDBParser.UPDATE, 0); }
		public TableSourcesContext tableSources() {
			return getRuleContext(TableSourcesContext.class,0);
		}
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public List updatedElement() {
			return getRuleContexts(UpdatedElementContext.class);
		}
		public UpdatedElementContext updatedElement(int i) {
			return getRuleContext(UpdatedElementContext.class,i);
		}
		public TerminalNode IGNORE() { return getToken(MariaDBParser.IGNORE, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode WHERE() { return getToken(MariaDBParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode LOW_PRIORITY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterMultipleUpdateStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMultipleUpdateStatement(this);
		}
	}

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

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

			setState(3841);
			tableSources();
			setState(3842);
			match(SET);
			setState(3843);
			updatedElement();
			setState(3848);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3844);
				match(COMMA);
				setState(3845);
				updatedElement();
				}
				}
				setState(3850);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(3853);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3851);
				match(WHERE);
				setState(3852);
				expression(0);
				}
			}

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

	public static class OrderByClauseContext extends ParserRuleContext {
		public TerminalNode ORDER() { return getToken(MariaDBParser.ORDER, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public List orderByExpression() {
			return getRuleContexts(OrderByExpressionContext.class);
		}
		public OrderByExpressionContext orderByExpression(int i) {
			return getRuleContext(OrderByExpressionContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterOrderByClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitOrderByClause(this);
		}
	}

	public final OrderByClauseContext orderByClause() throws RecognitionException {
		OrderByClauseContext _localctx = new OrderByClauseContext(_ctx, getState());
		enterRule(_localctx, 240, RULE_orderByClause);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(3855);
			match(ORDER);
			setState(3856);
			match(BY);
			setState(3857);
			orderByExpression();
			setState(3862);
			_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(3858);
					match(COMMA);
					setState(3859);
					orderByExpression();
					}
					} 
				}
				setState(3864);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,555,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class OrderByExpressionContext extends ParserRuleContext {
		public Token order;
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode ASC() { return getToken(MariaDBParser.ASC, 0); }
		public TerminalNode DESC() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterOrderByExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitOrderByExpression(this);
		}
	}

	public final OrderByExpressionContext orderByExpression() throws RecognitionException {
		OrderByExpressionContext _localctx = new OrderByExpressionContext(_ctx, getState());
		enterRule(_localctx, 242, RULE_orderByExpression);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3865);
			expression(0);
			setState(3867);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,556,_ctx) ) {
			case 1:
				{
				setState(3866);
				((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;
	}

	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableSources(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableSources(this);
		}
	}

	public final TableSourcesContext tableSources() throws RecognitionException {
		TableSourcesContext _localctx = new TableSourcesContext(_ctx, getState());
		enterRule(_localctx, 244, RULE_tableSources);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(3869);
			tableSource();
			setState(3874);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,557,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(3870);
					match(COMMA);
					setState(3871);
					tableSource();
					}
					} 
				}
				setState(3876);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,557,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableJson(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableJson(this);
		}
	}
	public static class TableSourceNestedContext extends TableSourceContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableSourceNested(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableSourceNested(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableSourceBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableSourceBase(this);
		}
	}

	public final TableSourceContext tableSource() throws RecognitionException {
		TableSourceContext _localctx = new TableSourceContext(_ctx, getState());
		enterRule(_localctx, 246, RULE_tableSource);
		int _la;
		try {
			int _alt;
			setState(3895);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,560,_ctx) ) {
			case 1:
				_localctx = new TableSourceBaseContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(3877);
				tableSourceItem();
				setState(3881);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,558,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(3878);
						joinPart();
						}
						} 
					}
					setState(3883);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,558,_ctx);
				}
				}
				break;
			case 2:
				_localctx = new TableSourceNestedContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(3884);
				match(LR_BRACKET);
				setState(3885);
				tableSourceItem();
				setState(3889);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (((((_la - 35)) & ~0x3f) == 0 && ((1L << (_la - 35)) & ((1L << (CROSS - 35)) | (1L << (INNER - 35)) | (1L << (JOIN - 35)) | (1L << (LEFT - 35)))) != 0) || ((((_la - 113)) & ~0x3f) == 0 && ((1L << (_la - 113)) & ((1L << (NATURAL - 113)) | (1L << (RIGHT - 113)) | (1L << (STRAIGHT_JOIN - 113)))) != 0)) {
					{
					{
					setState(3886);
					joinPart();
					}
					}
					setState(3891);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3892);
				match(RR_BRACKET);
				}
				break;
			case 3:
				_localctx = new TableJsonContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(3894);
				jsonTable();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	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(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public SubqueryTableItemContext(TableSourceItemContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSubqueryTableItem(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSubqueryTableItem(this);
		}
	}
	public static class AtomTableItemContext extends TableSourceItemContext {
		public UidContext alias;
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.AS, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public AtomTableItemContext(TableSourceItemContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAtomTableItem(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAtomTableItem(this);
		}
	}
	public static class TableSourcesItemContext extends TableSourceItemContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TableSourcesContext tableSources() {
			return getRuleContext(TableSourcesContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TableSourcesItemContext(TableSourceItemContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableSourcesItem(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableSourcesItem(this);
		}
	}

	public final TableSourceItemContext tableSourceItem() throws RecognitionException {
		TableSourceItemContext _localctx = new TableSourceItemContext(_ctx, getState());
		enterRule(_localctx, 248, RULE_tableSourceItem);
		int _la;
		try {
			int _alt;
			setState(3937);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,568,_ctx) ) {
			case 1:
				_localctx = new AtomTableItemContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(3897);
				tableName();
				setState(3903);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PARTITION) {
					{
					setState(3898);
					match(PARTITION);
					setState(3899);
					match(LR_BRACKET);
					setState(3900);
					uidList();
					setState(3901);
					match(RR_BRACKET);
					}
				}

				setState(3909);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,563,_ctx) ) {
				case 1:
					{
					setState(3906);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(3905);
						match(AS);
						}
					}

					setState(3908);
					((AtomTableItemContext)_localctx).alias = uid();
					}
					break;
				}
				setState(3919);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,565,_ctx) ) {
				case 1:
					{
					setState(3911);
					indexHint();
					setState(3916);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,564,_ctx);
					while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
						if ( _alt==1 ) {
							{
							{
							setState(3912);
							match(COMMA);
							setState(3913);
							indexHint();
							}
							} 
						}
						setState(3918);
						_errHandler.sync(this);
						_alt = getInterpreter().adaptivePredict(_input,564,_ctx);
					}
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new SubqueryTableItemContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(3926);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,566,_ctx) ) {
				case 1:
					{
					setState(3921);
					selectStatement();
					}
					break;
				case 2:
					{
					setState(3922);
					match(LR_BRACKET);
					setState(3923);
					((SubqueryTableItemContext)_localctx).parenthesisSubquery = selectStatement();
					setState(3924);
					match(RR_BRACKET);
					}
					break;
				}
				setState(3929);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(3928);
					match(AS);
					}
				}

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

	public static class IndexHintContext extends ParserRuleContext {
		public Token indexHintAction;
		public Token keyFormat;
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode USE() { return getToken(MariaDBParser.USE, 0); }
		public TerminalNode IGNORE() { return getToken(MariaDBParser.IGNORE, 0); }
		public TerminalNode FORCE() { return getToken(MariaDBParser.FORCE, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.KEY, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIndexHint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIndexHint(this);
		}
	}

	public final IndexHintContext indexHint() throws RecognitionException {
		IndexHintContext _localctx = new IndexHintContext(_ctx, getState());
		enterRule(_localctx, 250, RULE_indexHint);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3939);
			((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(3940);
			((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(3943);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FOR) {
				{
				setState(3941);
				match(FOR);
				setState(3942);
				indexHintType();
				}
			}

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

	public static class IndexHintTypeContext extends ParserRuleContext {
		public TerminalNode JOIN() { return getToken(MariaDBParser.JOIN, 0); }
		public TerminalNode ORDER() { return getToken(MariaDBParser.ORDER, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public TerminalNode GROUP() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIndexHintType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIndexHintType(this);
		}
	}

	public final IndexHintTypeContext indexHintType() throws RecognitionException {
		IndexHintTypeContext _localctx = new IndexHintTypeContext(_ctx, getState());
		enterRule(_localctx, 252, RULE_indexHintType);
		try {
			setState(3954);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case JOIN:
				enterOuterAlt(_localctx, 1);
				{
				setState(3949);
				match(JOIN);
				}
				break;
			case ORDER:
				enterOuterAlt(_localctx, 2);
				{
				setState(3950);
				match(ORDER);
				setState(3951);
				match(BY);
				}
				break;
			case GROUP:
				enterOuterAlt(_localctx, 3);
				{
				setState(3952);
				match(GROUP);
				setState(3953);
				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;
	}

	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);
		}
	}
	public static class InnerJoinContext extends JoinPartContext {
		public TerminalNode JOIN() { return getToken(MariaDBParser.JOIN, 0); }
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public TerminalNode LATERAL() { return getToken(MariaDBParser.LATERAL, 0); }
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode USING() { return getToken(MariaDBParser.USING, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode INNER() { return getToken(MariaDBParser.INNER, 0); }
		public TerminalNode CROSS() { return getToken(MariaDBParser.CROSS, 0); }
		public InnerJoinContext(JoinPartContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterInnerJoin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitInnerJoin(this);
		}
	}
	public static class NaturalJoinContext extends JoinPartContext {
		public TerminalNode NATURAL() { return getToken(MariaDBParser.NATURAL, 0); }
		public TerminalNode JOIN() { return getToken(MariaDBParser.JOIN, 0); }
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public TerminalNode LEFT() { return getToken(MariaDBParser.LEFT, 0); }
		public TerminalNode RIGHT() { return getToken(MariaDBParser.RIGHT, 0); }
		public TerminalNode OUTER() { return getToken(MariaDBParser.OUTER, 0); }
		public NaturalJoinContext(JoinPartContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterNaturalJoin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitNaturalJoin(this);
		}
	}
	public static class OuterJoinContext extends JoinPartContext {
		public TerminalNode JOIN() { return getToken(MariaDBParser.JOIN, 0); }
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public TerminalNode LEFT() { return getToken(MariaDBParser.LEFT, 0); }
		public TerminalNode RIGHT() { return getToken(MariaDBParser.RIGHT, 0); }
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode USING() { return getToken(MariaDBParser.USING, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode OUTER() { return getToken(MariaDBParser.OUTER, 0); }
		public TerminalNode LATERAL() { return getToken(MariaDBParser.LATERAL, 0); }
		public OuterJoinContext(JoinPartContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterOuterJoin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitOuterJoin(this);
		}
	}
	public static class StraightJoinContext extends JoinPartContext {
		public TerminalNode STRAIGHT_JOIN() { return getToken(MariaDBParser.STRAIGHT_JOIN, 0); }
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public StraightJoinContext(JoinPartContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterStraightJoin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStraightJoin(this);
		}
	}

	public final JoinPartContext joinPart() throws RecognitionException {
		JoinPartContext _localctx = new JoinPartContext(_ctx, getState());
		enterRule(_localctx, 254, RULE_joinPart);
		int _la;
		try {
			setState(4006);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CROSS:
			case INNER:
			case JOIN:
				_localctx = new InnerJoinContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(3957);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CROSS || _la==INNER) {
					{
					setState(3956);
					_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(3959);
				match(JOIN);
				setState(3961);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,572,_ctx) ) {
				case 1:
					{
					setState(3960);
					match(LATERAL);
					}
					break;
				}
				setState(3963);
				tableSourceItem();
				setState(3971);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,573,_ctx) ) {
				case 1:
					{
					setState(3964);
					match(ON);
					setState(3965);
					expression(0);
					}
					break;
				case 2:
					{
					setState(3966);
					match(USING);
					setState(3967);
					match(LR_BRACKET);
					setState(3968);
					uidList();
					setState(3969);
					match(RR_BRACKET);
					}
					break;
				}
				}
				break;
			case STRAIGHT_JOIN:
				_localctx = new StraightJoinContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(3973);
				match(STRAIGHT_JOIN);
				setState(3974);
				tableSourceItem();
				setState(3977);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,574,_ctx) ) {
				case 1:
					{
					setState(3975);
					match(ON);
					setState(3976);
					expression(0);
					}
					break;
				}
				}
				break;
			case LEFT:
			case RIGHT:
				_localctx = new OuterJoinContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(3979);
				_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(3981);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==OUTER) {
					{
					setState(3980);
					match(OUTER);
					}
				}

				setState(3983);
				match(JOIN);
				setState(3985);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,576,_ctx) ) {
				case 1:
					{
					setState(3984);
					match(LATERAL);
					}
					break;
				}
				setState(3987);
				tableSourceItem();
				setState(3995);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ON:
					{
					setState(3988);
					match(ON);
					setState(3989);
					expression(0);
					}
					break;
				case USING:
					{
					setState(3990);
					match(USING);
					setState(3991);
					match(LR_BRACKET);
					setState(3992);
					uidList();
					setState(3993);
					match(RR_BRACKET);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case NATURAL:
				_localctx = new NaturalJoinContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(3997);
				match(NATURAL);
				setState(4002);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LEFT || _la==RIGHT) {
					{
					setState(3998);
					_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(4000);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==OUTER) {
						{
						setState(3999);
						match(OUTER);
						}
					}

					}
				}

				setState(4004);
				match(JOIN);
				setState(4005);
				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;
	}

	public static class QueryExpressionContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public QuerySpecificationContext querySpecification() {
			return getRuleContext(QuerySpecificationContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterQueryExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitQueryExpression(this);
		}
	}

	public final QueryExpressionContext queryExpression() throws RecognitionException {
		QueryExpressionContext _localctx = new QueryExpressionContext(_ctx, getState());
		enterRule(_localctx, 256, RULE_queryExpression);
		try {
			setState(4016);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,581,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4008);
				match(LR_BRACKET);
				setState(4009);
				querySpecification();
				setState(4010);
				match(RR_BRACKET);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4012);
				match(LR_BRACKET);
				setState(4013);
				queryExpression();
				setState(4014);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class QueryExpressionNointoContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public QuerySpecificationNointoContext querySpecificationNointo() {
			return getRuleContext(QuerySpecificationNointoContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterQueryExpressionNointo(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitQueryExpressionNointo(this);
		}
	}

	public final QueryExpressionNointoContext queryExpressionNointo() throws RecognitionException {
		QueryExpressionNointoContext _localctx = new QueryExpressionNointoContext(_ctx, getState());
		enterRule(_localctx, 258, RULE_queryExpressionNointo);
		try {
			setState(4026);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,582,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4018);
				match(LR_BRACKET);
				setState(4019);
				querySpecificationNointo();
				setState(4020);
				match(RR_BRACKET);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4022);
				match(LR_BRACKET);
				setState(4023);
				queryExpressionNointo();
				setState(4024);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class QuerySpecificationContext extends ParserRuleContext {
		public TerminalNode SELECT() { return getToken(MariaDBParser.SELECT, 0); }
		public SelectElementsContext selectElements() {
			return getRuleContext(SelectElementsContext.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 FromClauseContext fromClause() {
			return getRuleContext(FromClauseContext.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterQuerySpecification(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitQuerySpecification(this);
		}
	}

	public final QuerySpecificationContext querySpecification() throws RecognitionException {
		QuerySpecificationContext _localctx = new QuerySpecificationContext(_ctx, getState());
		enterRule(_localctx, 260, RULE_querySpecification);
		int _la;
		try {
			int _alt;
			setState(4086);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,599,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4028);
				match(SELECT);
				setState(4032);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,583,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(4029);
						selectSpec();
						}
						} 
					}
					setState(4034);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,583,_ctx);
				}
				setState(4035);
				selectElements();
				setState(4037);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INTO) {
					{
					setState(4036);
					selectIntoExpression();
					}
				}

				setState(4040);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,585,_ctx) ) {
				case 1:
					{
					setState(4039);
					fromClause();
					}
					break;
				}
				setState(4043);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,586,_ctx) ) {
				case 1:
					{
					setState(4042);
					groupByClause();
					}
					break;
				}
				setState(4046);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==HAVING) {
					{
					setState(4045);
					havingClause();
					}
				}

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

				setState(4052);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,589,_ctx) ) {
				case 1:
					{
					setState(4051);
					orderByClause();
					}
					break;
				}
				setState(4055);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,590,_ctx) ) {
				case 1:
					{
					setState(4054);
					limitClause();
					}
					break;
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4057);
				match(SELECT);
				setState(4061);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,591,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(4058);
						selectSpec();
						}
						} 
					}
					setState(4063);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,591,_ctx);
				}
				setState(4064);
				selectElements();
				setState(4066);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,592,_ctx) ) {
				case 1:
					{
					setState(4065);
					fromClause();
					}
					break;
				}
				setState(4069);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,593,_ctx) ) {
				case 1:
					{
					setState(4068);
					groupByClause();
					}
					break;
				}
				setState(4072);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==HAVING) {
					{
					setState(4071);
					havingClause();
					}
				}

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

				setState(4078);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,596,_ctx) ) {
				case 1:
					{
					setState(4077);
					orderByClause();
					}
					break;
				}
				setState(4081);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,597,_ctx) ) {
				case 1:
					{
					setState(4080);
					limitClause();
					}
					break;
				}
				setState(4084);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INTO) {
					{
					setState(4083);
					selectIntoExpression();
					}
				}

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

	public static class QuerySpecificationNointoContext extends ParserRuleContext {
		public TerminalNode SELECT() { return getToken(MariaDBParser.SELECT, 0); }
		public SelectElementsContext selectElements() {
			return getRuleContext(SelectElementsContext.class,0);
		}
		public List selectSpec() {
			return getRuleContexts(SelectSpecContext.class);
		}
		public SelectSpecContext selectSpec(int i) {
			return getRuleContext(SelectSpecContext.class,i);
		}
		public FromClauseContext fromClause() {
			return getRuleContext(FromClauseContext.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 QuerySpecificationNointoContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_querySpecificationNointo; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterQuerySpecificationNointo(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitQuerySpecificationNointo(this);
		}
	}

	public final QuerySpecificationNointoContext querySpecificationNointo() throws RecognitionException {
		QuerySpecificationNointoContext _localctx = new QuerySpecificationNointoContext(_ctx, getState());
		enterRule(_localctx, 262, RULE_querySpecificationNointo);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4088);
			match(SELECT);
			setState(4092);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,600,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4089);
					selectSpec();
					}
					} 
				}
				setState(4094);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,600,_ctx);
			}
			setState(4095);
			selectElements();
			setState(4097);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,601,_ctx) ) {
			case 1:
				{
				setState(4096);
				fromClause();
				}
				break;
			}
			setState(4100);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,602,_ctx) ) {
			case 1:
				{
				setState(4099);
				groupByClause();
				}
				break;
			}
			setState(4103);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==HAVING) {
				{
				setState(4102);
				havingClause();
				}
			}

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

			setState(4109);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,605,_ctx) ) {
			case 1:
				{
				setState(4108);
				orderByClause();
				}
				break;
			}
			setState(4112);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,606,_ctx) ) {
			case 1:
				{
				setState(4111);
				limitClause();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class UnionParenthesisContext extends ParserRuleContext {
		public Token unionType;
		public TerminalNode UNION() { return getToken(MariaDBParser.UNION, 0); }
		public QueryExpressionNointoContext queryExpressionNointo() {
			return getRuleContext(QueryExpressionNointoContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUnionParenthesis(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUnionParenthesis(this);
		}
	}

	public final UnionParenthesisContext unionParenthesis() throws RecognitionException {
		UnionParenthesisContext _localctx = new UnionParenthesisContext(_ctx, getState());
		enterRule(_localctx, 264, RULE_unionParenthesis);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4114);
			match(UNION);
			setState(4116);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ALL || _la==DISTINCT) {
				{
				setState(4115);
				((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(4118);
			queryExpressionNointo();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class UnionStatementContext extends ParserRuleContext {
		public Token unionType;
		public TerminalNode UNION() { return getToken(MariaDBParser.UNION, 0); }
		public QuerySpecificationNointoContext querySpecificationNointo() {
			return getRuleContext(QuerySpecificationNointoContext.class,0);
		}
		public QueryExpressionNointoContext queryExpressionNointo() {
			return getRuleContext(QueryExpressionNointoContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUnionStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUnionStatement(this);
		}
	}

	public final UnionStatementContext unionStatement() throws RecognitionException {
		UnionStatementContext _localctx = new UnionStatementContext(_ctx, getState());
		enterRule(_localctx, 266, RULE_unionStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4120);
			match(UNION);
			setState(4122);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ALL || _la==DISTINCT) {
				{
				setState(4121);
				((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(4126);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SELECT:
				{
				setState(4124);
				querySpecificationNointo();
				}
				break;
			case LR_BRACKET:
				{
				setState(4125);
				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;
	}

	public static class LateralStatementContext extends ParserRuleContext {
		public TerminalNode LATERAL() { return getToken(MariaDBParser.LATERAL, 0); }
		public QuerySpecificationNointoContext querySpecificationNointo() {
			return getRuleContext(QuerySpecificationNointoContext.class,0);
		}
		public QueryExpressionNointoContext queryExpressionNointo() {
			return getRuleContext(QueryExpressionNointoContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLateralStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLateralStatement(this);
		}
	}

	public final LateralStatementContext lateralStatement() throws RecognitionException {
		LateralStatementContext _localctx = new LateralStatementContext(_ctx, getState());
		enterRule(_localctx, 268, RULE_lateralStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4128);
			match(LATERAL);
			setState(4143);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,613,_ctx) ) {
			case 1:
				{
				setState(4129);
				querySpecificationNointo();
				}
				break;
			case 2:
				{
				setState(4130);
				queryExpressionNointo();
				}
				break;
			case 3:
				{
				{
				setState(4131);
				match(LR_BRACKET);
				setState(4134);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case SELECT:
					{
					setState(4132);
					querySpecificationNointo();
					}
					break;
				case LR_BRACKET:
					{
					setState(4133);
					queryExpressionNointo();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(4136);
				match(RR_BRACKET);
				setState(4141);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,612,_ctx) ) {
				case 1:
					{
					setState(4138);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(4137);
						match(AS);
						}
					}

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

	public static class JsonTableContext extends ParserRuleContext {
		public TerminalNode JSON_TABLE() { return getToken(MariaDBParser.JSON_TABLE, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.LR_BRACKET, i);
		}
		public List STRING_LITERAL() { return getTokens(MariaDBParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MariaDBParser.STRING_LITERAL, i);
		}
		public TerminalNode COMMA() { return getToken(MariaDBParser.COMMA, 0); }
		public TerminalNode COLUMNS() { return getToken(MariaDBParser.COLUMNS, 0); }
		public JsonColumnListContext jsonColumnList() {
			return getRuleContext(JsonColumnListContext.class,0);
		}
		public List RR_BRACKET() { return getTokens(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.RR_BRACKET, i);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterJsonTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitJsonTable(this);
		}
	}

	public final JsonTableContext jsonTable() throws RecognitionException {
		JsonTableContext _localctx = new JsonTableContext(_ctx, getState());
		enterRule(_localctx, 270, RULE_jsonTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4145);
			match(JSON_TABLE);
			setState(4146);
			match(LR_BRACKET);
			setState(4147);
			match(STRING_LITERAL);
			setState(4148);
			match(COMMA);
			setState(4149);
			match(STRING_LITERAL);
			setState(4150);
			match(COLUMNS);
			setState(4151);
			match(LR_BRACKET);
			setState(4152);
			jsonColumnList();
			setState(4153);
			match(RR_BRACKET);
			setState(4154);
			match(RR_BRACKET);
			setState(4159);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,615,_ctx) ) {
			case 1:
				{
				setState(4156);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(4155);
					match(AS);
					}
				}

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

	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterJsonColumnList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitJsonColumnList(this);
		}
	}

	public final JsonColumnListContext jsonColumnList() throws RecognitionException {
		JsonColumnListContext _localctx = new JsonColumnListContext(_ctx, getState());
		enterRule(_localctx, 272, RULE_jsonColumnList);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4161);
			jsonColumn();
			setState(4166);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4162);
				match(COMMA);
				setState(4163);
				jsonColumn();
				}
				}
				setState(4168);
				_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;
	}

	public static class JsonColumnContext extends ParserRuleContext {
		public FullColumnNameContext fullColumnName() {
			return getRuleContext(FullColumnNameContext.class,0);
		}
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode ORDINALITY() { return getToken(MariaDBParser.ORDINALITY, 0); }
		public DataTypeContext dataType() {
			return getRuleContext(DataTypeContext.class,0);
		}
		public TerminalNode PATH() { return getToken(MariaDBParser.PATH, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode EXISTS() { return getToken(MariaDBParser.EXISTS, 0); }
		public JsonOnEmptyContext jsonOnEmpty() {
			return getRuleContext(JsonOnEmptyContext.class,0);
		}
		public JsonOnErrorContext jsonOnError() {
			return getRuleContext(JsonOnErrorContext.class,0);
		}
		public TerminalNode NESTED() { return getToken(MariaDBParser.NESTED, 0); }
		public TerminalNode COLUMNS() { return getToken(MariaDBParser.COLUMNS, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public JsonColumnListContext jsonColumnList() {
			return getRuleContext(JsonColumnListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterJsonColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitJsonColumn(this);
		}
	}

	public final JsonColumnContext jsonColumn() throws RecognitionException {
		JsonColumnContext _localctx = new JsonColumnContext(_ctx, getState());
		enterRule(_localctx, 274, RULE_jsonColumn);
		int _la;
		try {
			setState(4198);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,622,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4169);
				fullColumnName();
				setState(4186);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case FOR:
					{
					setState(4170);
					match(FOR);
					setState(4171);
					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(4172);
					dataType();
					setState(4184);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case PATH:
						{
						setState(4173);
						match(PATH);
						setState(4174);
						match(STRING_LITERAL);
						setState(4176);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,617,_ctx) ) {
						case 1:
							{
							setState(4175);
							jsonOnEmpty();
							}
							break;
						}
						setState(4179);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==DEFAULT || _la==NULL_LITERAL || _la==ERROR) {
							{
							setState(4178);
							jsonOnError();
							}
						}

						}
						break;
					case EXISTS:
						{
						setState(4181);
						match(EXISTS);
						setState(4182);
						match(PATH);
						setState(4183);
						match(STRING_LITERAL);
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4188);
				match(NESTED);
				setState(4190);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PATH) {
					{
					setState(4189);
					match(PATH);
					}
				}

				setState(4192);
				match(STRING_LITERAL);
				setState(4193);
				match(COLUMNS);
				setState(4194);
				match(LR_BRACKET);
				setState(4195);
				jsonColumnList();
				setState(4196);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class JsonOnEmptyContext extends ParserRuleContext {
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public TerminalNode EMPTY() { return getToken(MariaDBParser.EMPTY, 0); }
		public TerminalNode NULL_LITERAL() { return getToken(MariaDBParser.NULL_LITERAL, 0); }
		public TerminalNode ERROR() { return getToken(MariaDBParser.ERROR, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterJsonOnEmpty(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitJsonOnEmpty(this);
		}
	}

	public final JsonOnEmptyContext jsonOnEmpty() throws RecognitionException {
		JsonOnEmptyContext _localctx = new JsonOnEmptyContext(_ctx, getState());
		enterRule(_localctx, 276, RULE_jsonOnEmpty);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4204);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case NULL_LITERAL:
				{
				setState(4200);
				match(NULL_LITERAL);
				}
				break;
			case ERROR:
				{
				setState(4201);
				match(ERROR);
				}
				break;
			case DEFAULT:
				{
				setState(4202);
				match(DEFAULT);
				setState(4203);
				defaultValue();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(4206);
			match(ON);
			setState(4207);
			match(EMPTY);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class JsonOnErrorContext extends ParserRuleContext {
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public List ERROR() { return getTokens(MariaDBParser.ERROR); }
		public TerminalNode ERROR(int i) {
			return getToken(MariaDBParser.ERROR, i);
		}
		public TerminalNode NULL_LITERAL() { return getToken(MariaDBParser.NULL_LITERAL, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterJsonOnError(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitJsonOnError(this);
		}
	}

	public final JsonOnErrorContext jsonOnError() throws RecognitionException {
		JsonOnErrorContext _localctx = new JsonOnErrorContext(_ctx, getState());
		enterRule(_localctx, 278, RULE_jsonOnError);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4213);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case NULL_LITERAL:
				{
				setState(4209);
				match(NULL_LITERAL);
				}
				break;
			case ERROR:
				{
				setState(4210);
				match(ERROR);
				}
				break;
			case DEFAULT:
				{
				setState(4211);
				match(DEFAULT);
				setState(4212);
				defaultValue();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(4215);
			match(ON);
			setState(4216);
			match(ERROR);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class SelectSpecContext extends ParserRuleContext {
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MariaDBParser.DISTINCT, 0); }
		public TerminalNode DISTINCTROW() { return getToken(MariaDBParser.DISTINCTROW, 0); }
		public TerminalNode HIGH_PRIORITY() { return getToken(MariaDBParser.HIGH_PRIORITY, 0); }
		public TerminalNode STRAIGHT_JOIN() { return getToken(MariaDBParser.STRAIGHT_JOIN, 0); }
		public TerminalNode SQL_SMALL_RESULT() { return getToken(MariaDBParser.SQL_SMALL_RESULT, 0); }
		public TerminalNode SQL_BIG_RESULT() { return getToken(MariaDBParser.SQL_BIG_RESULT, 0); }
		public TerminalNode SQL_BUFFER_RESULT() { return getToken(MariaDBParser.SQL_BUFFER_RESULT, 0); }
		public TerminalNode SQL_CACHE() { return getToken(MariaDBParser.SQL_CACHE, 0); }
		public TerminalNode SQL_NO_CACHE() { return getToken(MariaDBParser.SQL_NO_CACHE, 0); }
		public TerminalNode SQL_CALC_FOUND_ROWS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectSpec(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectSpec(this);
		}
	}

	public final SelectSpecContext selectSpec() throws RecognitionException {
		SelectSpecContext _localctx = new SelectSpecContext(_ctx, getState());
		enterRule(_localctx, 280, RULE_selectSpec);
		int _la;
		try {
			setState(4226);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ALL:
			case DISTINCT:
			case DISTINCTROW:
				enterOuterAlt(_localctx, 1);
				{
				setState(4218);
				_la = _input.LA(1);
				if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << ALL) | (1L << DISTINCT) | (1L << DISTINCTROW))) != 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(4219);
				match(HIGH_PRIORITY);
				}
				break;
			case STRAIGHT_JOIN:
				enterOuterAlt(_localctx, 3);
				{
				setState(4220);
				match(STRAIGHT_JOIN);
				}
				break;
			case SQL_SMALL_RESULT:
				enterOuterAlt(_localctx, 4);
				{
				setState(4221);
				match(SQL_SMALL_RESULT);
				}
				break;
			case SQL_BIG_RESULT:
				enterOuterAlt(_localctx, 5);
				{
				setState(4222);
				match(SQL_BIG_RESULT);
				}
				break;
			case SQL_BUFFER_RESULT:
				enterOuterAlt(_localctx, 6);
				{
				setState(4223);
				match(SQL_BUFFER_RESULT);
				}
				break;
			case SQL_CACHE:
			case SQL_NO_CACHE:
				enterOuterAlt(_localctx, 7);
				{
				setState(4224);
				_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(4225);
				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;
	}

	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(MariaDBParser.STAR, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectElements(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectElements(this);
		}
	}

	public final SelectElementsContext selectElements() throws RecognitionException {
		SelectElementsContext _localctx = new SelectElementsContext(_ctx, getState());
		enterRule(_localctx, 282, RULE_selectElements);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4230);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,626,_ctx) ) {
			case 1:
				{
				setState(4228);
				((SelectElementsContext)_localctx).star = match(STAR);
				}
				break;
			case 2:
				{
				setState(4229);
				selectElement();
				}
				break;
			}
			setState(4236);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,627,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4232);
					match(COMMA);
					setState(4233);
					selectElement();
					}
					} 
				}
				setState(4238);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,627,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class SelectExpressionElementContext extends SelectElementContext {
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode LOCAL_ID() { return getToken(MariaDBParser.LOCAL_ID, 0); }
		public TerminalNode VAR_ASSIGN() { return getToken(MariaDBParser.VAR_ASSIGN, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public SelectExpressionElementContext(SelectElementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectExpressionElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectExpressionElement(this);
		}
	}
	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(MariaDBParser.AS, 0); }
		public SelectFunctionElementContext(SelectElementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectFunctionElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectFunctionElement(this);
		}
	}
	public static class SelectStarElementContext extends SelectElementContext {
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode DOT() { return getToken(MariaDBParser.DOT, 0); }
		public TerminalNode STAR() { return getToken(MariaDBParser.STAR, 0); }
		public SelectStarElementContext(SelectElementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectStarElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectStarElement(this);
		}
	}
	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(MariaDBParser.AS, 0); }
		public SelectColumnElementContext(SelectElementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectColumnElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectColumnElement(this);
		}
	}

	public final SelectElementContext selectElement() throws RecognitionException {
		SelectElementContext _localctx = new SelectElementContext(_ctx, getState());
		enterRule(_localctx, 284, RULE_selectElement);
		int _la;
		try {
			setState(4268);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,635,_ctx) ) {
			case 1:
				_localctx = new SelectStarElementContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4239);
				fullId();
				setState(4240);
				match(DOT);
				setState(4241);
				match(STAR);
				}
				break;
			case 2:
				_localctx = new SelectColumnElementContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4243);
				fullColumnName();
				setState(4248);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,629,_ctx) ) {
				case 1:
					{
					setState(4245);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(4244);
						match(AS);
						}
					}

					setState(4247);
					uid();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new SelectFunctionElementContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4250);
				functionCall();
				setState(4255);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,631,_ctx) ) {
				case 1:
					{
					setState(4252);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(4251);
						match(AS);
						}
					}

					setState(4254);
					uid();
					}
					break;
				}
				}
				break;
			case 4:
				_localctx = new SelectExpressionElementContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(4259);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,632,_ctx) ) {
				case 1:
					{
					setState(4257);
					match(LOCAL_ID);
					setState(4258);
					match(VAR_ASSIGN);
					}
					break;
				}
				setState(4261);
				expression(0);
				setState(4266);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,634,_ctx) ) {
				case 1:
					{
					setState(4263);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(4262);
						match(AS);
						}
					}

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

	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);
		}
	}
	public static class SelectIntoVariablesContext extends SelectIntoExpressionContext {
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public List assignmentField() {
			return getRuleContexts(AssignmentFieldContext.class);
		}
		public AssignmentFieldContext assignmentField(int i) {
			return getRuleContext(AssignmentFieldContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public SelectIntoVariablesContext(SelectIntoExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectIntoVariables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectIntoVariables(this);
		}
	}
	public static class SelectIntoTextFileContext extends SelectIntoExpressionContext {
		public Token filename;
		public CharsetNameContext charset;
		public Token fieldsFormat;
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public TerminalNode OUTFILE() { return getToken(MariaDBParser.OUTFILE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode CHARACTER() { return getToken(MariaDBParser.CHARACTER, 0); }
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode LINES() { return getToken(MariaDBParser.LINES, 0); }
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode FIELDS() { return getToken(MariaDBParser.FIELDS, 0); }
		public TerminalNode COLUMNS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectIntoTextFile(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectIntoTextFile(this);
		}
	}
	public static class SelectIntoDumpFileContext extends SelectIntoExpressionContext {
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public TerminalNode DUMPFILE() { return getToken(MariaDBParser.DUMPFILE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public SelectIntoDumpFileContext(SelectIntoExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectIntoDumpFile(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectIntoDumpFile(this);
		}
	}

	public final SelectIntoExpressionContext selectIntoExpression() throws RecognitionException {
		SelectIntoExpressionContext _localctx = new SelectIntoExpressionContext(_ctx, getState());
		enterRule(_localctx, 286, RULE_selectIntoExpression);
		int _la;
		try {
			setState(4306);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,642,_ctx) ) {
			case 1:
				_localctx = new SelectIntoVariablesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4270);
				match(INTO);
				setState(4271);
				assignmentField();
				setState(4276);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4272);
					match(COMMA);
					setState(4273);
					assignmentField();
					}
					}
					setState(4278);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new SelectIntoDumpFileContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4279);
				match(INTO);
				setState(4280);
				match(DUMPFILE);
				setState(4281);
				match(STRING_LITERAL);
				}
				break;
			case 3:
				_localctx = new SelectIntoTextFileContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				{
				setState(4282);
				match(INTO);
				setState(4283);
				match(OUTFILE);
				setState(4284);
				((SelectIntoTextFileContext)_localctx).filename = match(STRING_LITERAL);
				setState(4288);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CHARACTER) {
					{
					setState(4285);
					match(CHARACTER);
					setState(4286);
					match(SET);
					setState(4287);
					((SelectIntoTextFileContext)_localctx).charset = charsetName();
					}
				}

				setState(4296);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,639,_ctx) ) {
				case 1:
					{
					setState(4290);
					((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(4292); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(4291);
						selectFieldsInto();
						}
						}
						setState(4294); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( _la==ENCLOSED || _la==ESCAPED || _la==OPTIONALLY || _la==TERMINATED );
					}
					break;
				}
				setState(4304);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LINES) {
					{
					setState(4298);
					match(LINES);
					setState(4300); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(4299);
						selectLinesInto();
						}
						}
						setState(4302); 
						_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;
	}

	public static class SelectFieldsIntoContext extends ParserRuleContext {
		public Token terminationField;
		public Token enclosion;
		public Token escaping;
		public TerminalNode TERMINATED() { return getToken(MariaDBParser.TERMINATED, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode ENCLOSED() { return getToken(MariaDBParser.ENCLOSED, 0); }
		public TerminalNode OPTIONALLY() { return getToken(MariaDBParser.OPTIONALLY, 0); }
		public TerminalNode ESCAPED() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectFieldsInto(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectFieldsInto(this);
		}
	}

	public final SelectFieldsIntoContext selectFieldsInto() throws RecognitionException {
		SelectFieldsIntoContext _localctx = new SelectFieldsIntoContext(_ctx, getState());
		enterRule(_localctx, 288, RULE_selectFieldsInto);
		int _la;
		try {
			setState(4320);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case TERMINATED:
				enterOuterAlt(_localctx, 1);
				{
				setState(4308);
				match(TERMINATED);
				setState(4309);
				match(BY);
				setState(4310);
				((SelectFieldsIntoContext)_localctx).terminationField = match(STRING_LITERAL);
				}
				break;
			case ENCLOSED:
			case OPTIONALLY:
				enterOuterAlt(_localctx, 2);
				{
				setState(4312);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==OPTIONALLY) {
					{
					setState(4311);
					match(OPTIONALLY);
					}
				}

				setState(4314);
				match(ENCLOSED);
				setState(4315);
				match(BY);
				setState(4316);
				((SelectFieldsIntoContext)_localctx).enclosion = match(STRING_LITERAL);
				}
				break;
			case ESCAPED:
				enterOuterAlt(_localctx, 3);
				{
				setState(4317);
				match(ESCAPED);
				setState(4318);
				match(BY);
				setState(4319);
				((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;
	}

	public static class SelectLinesIntoContext extends ParserRuleContext {
		public Token starting;
		public Token terminationLine;
		public TerminalNode STARTING() { return getToken(MariaDBParser.STARTING, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode TERMINATED() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSelectLinesInto(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSelectLinesInto(this);
		}
	}

	public final SelectLinesIntoContext selectLinesInto() throws RecognitionException {
		SelectLinesIntoContext _localctx = new SelectLinesIntoContext(_ctx, getState());
		enterRule(_localctx, 290, RULE_selectLinesInto);
		try {
			setState(4328);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case STARTING:
				enterOuterAlt(_localctx, 1);
				{
				setState(4322);
				match(STARTING);
				setState(4323);
				match(BY);
				setState(4324);
				((SelectLinesIntoContext)_localctx).starting = match(STRING_LITERAL);
				}
				break;
			case TERMINATED:
				enterOuterAlt(_localctx, 2);
				{
				setState(4325);
				match(TERMINATED);
				setState(4326);
				match(BY);
				setState(4327);
				((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;
	}

	public static class FromClauseContext extends ParserRuleContext {
		public ExpressionContext whereExpr;
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public TableSourcesContext tableSources() {
			return getRuleContext(TableSourcesContext.class,0);
		}
		public TerminalNode WHERE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFromClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFromClause(this);
		}
	}

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

			setState(4336);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(4334);
				match(WHERE);
				setState(4335);
				((FromClauseContext)_localctx).whereExpr = expression(0);
				}
			}

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

	public static class GroupByClauseContext extends ParserRuleContext {
		public TerminalNode GROUP() { return getToken(MariaDBParser.GROUP, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public List groupByItem() {
			return getRuleContexts(GroupByItemContext.class);
		}
		public GroupByItemContext groupByItem(int i) {
			return getRuleContext(GroupByItemContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public TerminalNode ROLLUP() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterGroupByClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitGroupByClause(this);
		}
	}

	public final GroupByClauseContext groupByClause() throws RecognitionException {
		GroupByClauseContext _localctx = new GroupByClauseContext(_ctx, getState());
		enterRule(_localctx, 294, RULE_groupByClause);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4338);
			match(GROUP);
			setState(4339);
			match(BY);
			setState(4340);
			groupByItem();
			setState(4345);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,648,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4341);
					match(COMMA);
					setState(4342);
					groupByItem();
					}
					} 
				}
				setState(4347);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,648,_ctx);
			}
			setState(4350);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,649,_ctx) ) {
			case 1:
				{
				setState(4348);
				match(WITH);
				setState(4349);
				match(ROLLUP);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class HavingClauseContext extends ParserRuleContext {
		public ExpressionContext havingExpr;
		public TerminalNode HAVING() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHavingClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHavingClause(this);
		}
	}

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

	public static class WindowClauseContext extends ParserRuleContext {
		public TerminalNode WINDOW() { return getToken(MariaDBParser.WINDOW, 0); }
		public List windowName() {
			return getRuleContexts(WindowNameContext.class);
		}
		public WindowNameContext windowName(int i) {
			return getRuleContext(WindowNameContext.class,i);
		}
		public List AS() { return getTokens(MariaDBParser.AS); }
		public TerminalNode AS(int i) {
			return getToken(MariaDBParser.AS, i);
		}
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.RR_BRACKET, i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterWindowClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitWindowClause(this);
		}
	}

	public final WindowClauseContext windowClause() throws RecognitionException {
		WindowClauseContext _localctx = new WindowClauseContext(_ctx, getState());
		enterRule(_localctx, 298, RULE_windowClause);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4355);
			match(WINDOW);
			setState(4356);
			windowName();
			setState(4357);
			match(AS);
			setState(4358);
			match(LR_BRACKET);
			setState(4359);
			windowSpec();
			setState(4360);
			match(RR_BRACKET);
			setState(4370);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,650,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4361);
					match(COMMA);
					setState(4362);
					windowName();
					setState(4363);
					match(AS);
					setState(4364);
					match(LR_BRACKET);
					setState(4365);
					windowSpec();
					setState(4366);
					match(RR_BRACKET);
					}
					} 
				}
				setState(4372);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,650,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class GroupByItemContext extends ParserRuleContext {
		public Token order;
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode ASC() { return getToken(MariaDBParser.ASC, 0); }
		public TerminalNode DESC() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterGroupByItem(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitGroupByItem(this);
		}
	}

	public final GroupByItemContext groupByItem() throws RecognitionException {
		GroupByItemContext _localctx = new GroupByItemContext(_ctx, getState());
		enterRule(_localctx, 300, RULE_groupByItem);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4373);
			expression(0);
			setState(4375);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,651,_ctx) ) {
			case 1:
				{
				setState(4374);
				((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;
	}

	public static class LimitClauseContext extends ParserRuleContext {
		public LimitClauseAtomContext offset;
		public LimitClauseAtomContext limit;
		public TerminalNode LIMIT() { return getToken(MariaDBParser.LIMIT, 0); }
		public TerminalNode OFFSET() { return getToken(MariaDBParser.OFFSET, 0); }
		public List limitClauseAtom() {
			return getRuleContexts(LimitClauseAtomContext.class);
		}
		public LimitClauseAtomContext limitClauseAtom(int i) {
			return getRuleContext(LimitClauseAtomContext.class,i);
		}
		public TerminalNode COMMA() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLimitClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLimitClause(this);
		}
	}

	public final LimitClauseContext limitClause() throws RecognitionException {
		LimitClauseContext _localctx = new LimitClauseContext(_ctx, getState());
		enterRule(_localctx, 302, RULE_limitClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4377);
			match(LIMIT);
			setState(4388);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,653,_ctx) ) {
			case 1:
				{
				setState(4381);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,652,_ctx) ) {
				case 1:
					{
					setState(4378);
					((LimitClauseContext)_localctx).offset = limitClauseAtom();
					setState(4379);
					match(COMMA);
					}
					break;
				}
				setState(4383);
				((LimitClauseContext)_localctx).limit = limitClauseAtom();
				}
				break;
			case 2:
				{
				setState(4384);
				((LimitClauseContext)_localctx).limit = limitClauseAtom();
				setState(4385);
				match(OFFSET);
				setState(4386);
				((LimitClauseContext)_localctx).offset = limitClauseAtom();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLimitClauseAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLimitClauseAtom(this);
		}
	}

	public final LimitClauseAtomContext limitClauseAtom() throws RecognitionException {
		LimitClauseAtomContext _localctx = new LimitClauseAtomContext(_ctx, getState());
		enterRule(_localctx, 304, RULE_limitClauseAtom);
		try {
			setState(4393);
			_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(4390);
				decimalLiteral();
				}
				break;
			case LOCAL_ID:
			case GLOBAL_ID:
				enterOuterAlt(_localctx, 2);
				{
				setState(4391);
				mysqlVariable();
				}
				break;
			case ATTRIBUTE:
			case BODY:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_ROLE:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case LOCKED:
			case MAXVALUE:
			case MINVALUE:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case PACKAGE:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_:
			case STACKED:
			case STATEMENT:
			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 CYCLE:
			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 ENCRYPTED:
			case ENCRYPTION:
			case ENCRYPTION_KEY_ID:
			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 INCREMENT:
			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 LOCALES:
			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 NOCACHE:
			case NOCOPY:
			case NOCYCLE:
			case NOMAXVALUE:
			case NOMINVALUE:
			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 QUERY_RESPONSE_TIME:
			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 RESTART:
			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 SEQUENCE:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLAVES:
			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 TYPES:
			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 WSREP_MEMBERSHIP:
			case WSREP_STATUS:
			case X509:
			case XA:
			case XML:
			case YES:
			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 USER_STATISTICS:
			case CLIENT_STATISTICS:
			case INDEX_STATISTICS:
			case TABLE_STATISTICS:
			case ADMIN:
			case AUDIT_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_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_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 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 VIA:
			case LASTVAL:
			case NEXTVAL:
			case SETVAL:
			case PREVIOUS:
			case PERSISTENT:
			case BINLOG_MONITOR:
			case BINLOG_REPLAY:
			case FEDERATED_ADMIN:
			case READ_ONLY_ADMIN:
			case REPLICA:
			case REPLICAS:
			case REPLICATION_MASTER_ADMIN:
			case MONITOR:
			case READ_ONLY:
			case REPLAY:
			case MOD:
			case ID:
				enterOuterAlt(_localctx, 3);
				{
				setState(4392);
				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;
	}

	public static class StartTransactionContext extends ParserRuleContext {
		public TerminalNode START() { return getToken(MariaDBParser.START, 0); }
		public TerminalNode TRANSACTION() { return getToken(MariaDBParser.TRANSACTION, 0); }
		public List transactionMode() {
			return getRuleContexts(TransactionModeContext.class);
		}
		public TransactionModeContext transactionMode(int i) {
			return getRuleContext(TransactionModeContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterStartTransaction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStartTransaction(this);
		}
	}

	public final StartTransactionContext startTransaction() throws RecognitionException {
		StartTransactionContext _localctx = new StartTransactionContext(_ctx, getState());
		enterRule(_localctx, 306, RULE_startTransaction);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4395);
			match(START);
			setState(4396);
			match(TRANSACTION);
			setState(4405);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==READ || _la==WITH) {
				{
				setState(4397);
				transactionMode();
				setState(4402);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4398);
					match(COMMA);
					setState(4399);
					transactionMode();
					}
					}
					setState(4404);
					_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;
	}

	public static class BeginWorkContext extends ParserRuleContext {
		public TerminalNode BEGIN() { return getToken(MariaDBParser.BEGIN, 0); }
		public TerminalNode WORK() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterBeginWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitBeginWork(this);
		}
	}

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

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

	public static class CommitWorkContext extends ParserRuleContext {
		public Token nochain;
		public Token norelease;
		public TerminalNode COMMIT() { return getToken(MariaDBParser.COMMIT, 0); }
		public TerminalNode WORK() { return getToken(MariaDBParser.WORK, 0); }
		public TerminalNode AND() { return getToken(MariaDBParser.AND, 0); }
		public TerminalNode CHAIN() { return getToken(MariaDBParser.CHAIN, 0); }
		public TerminalNode RELEASE() { return getToken(MariaDBParser.RELEASE, 0); }
		public List NO() { return getTokens(MariaDBParser.NO); }
		public TerminalNode NO(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCommitWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCommitWork(this);
		}
	}

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

			setState(4420);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==AND) {
				{
				setState(4415);
				match(AND);
				setState(4417);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NO) {
					{
					setState(4416);
					((CommitWorkContext)_localctx).nochain = match(NO);
					}
				}

				setState(4419);
				match(CHAIN);
				}
			}

			setState(4426);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,662,_ctx) ) {
			case 1:
				{
				setState(4423);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NO) {
					{
					setState(4422);
					((CommitWorkContext)_localctx).norelease = match(NO);
					}
				}

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

	public static class RollbackWorkContext extends ParserRuleContext {
		public Token nochain;
		public Token norelease;
		public TerminalNode ROLLBACK() { return getToken(MariaDBParser.ROLLBACK, 0); }
		public TerminalNode WORK() { return getToken(MariaDBParser.WORK, 0); }
		public TerminalNode AND() { return getToken(MariaDBParser.AND, 0); }
		public TerminalNode CHAIN() { return getToken(MariaDBParser.CHAIN, 0); }
		public TerminalNode RELEASE() { return getToken(MariaDBParser.RELEASE, 0); }
		public List NO() { return getTokens(MariaDBParser.NO); }
		public TerminalNode NO(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRollbackWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRollbackWork(this);
		}
	}

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

			setState(4437);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==AND) {
				{
				setState(4432);
				match(AND);
				setState(4434);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NO) {
					{
					setState(4433);
					((RollbackWorkContext)_localctx).nochain = match(NO);
					}
				}

				setState(4436);
				match(CHAIN);
				}
			}

			setState(4443);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,667,_ctx) ) {
			case 1:
				{
				setState(4440);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NO) {
					{
					setState(4439);
					((RollbackWorkContext)_localctx).norelease = match(NO);
					}
				}

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

	public static class SavepointStatementContext extends ParserRuleContext {
		public TerminalNode SAVEPOINT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSavepointStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSavepointStatement(this);
		}
	}

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

	public static class RollbackStatementContext extends ParserRuleContext {
		public TerminalNode ROLLBACK() { return getToken(MariaDBParser.ROLLBACK, 0); }
		public TerminalNode TO() { return getToken(MariaDBParser.TO, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode WORK() { return getToken(MariaDBParser.WORK, 0); }
		public TerminalNode SAVEPOINT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRollbackStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRollbackStatement(this);
		}
	}

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

			setState(4452);
			match(TO);
			setState(4454);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,669,_ctx) ) {
			case 1:
				{
				setState(4453);
				match(SAVEPOINT);
				}
				break;
			}
			setState(4456);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ReleaseStatementContext extends ParserRuleContext {
		public TerminalNode RELEASE() { return getToken(MariaDBParser.RELEASE, 0); }
		public TerminalNode SAVEPOINT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterReleaseStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitReleaseStatement(this);
		}
	}

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

	public static class LockTablesContext extends ParserRuleContext {
		public TerminalNode LOCK() { return getToken(MariaDBParser.LOCK, 0); }
		public List lockTableElement() {
			return getRuleContexts(LockTableElementContext.class);
		}
		public LockTableElementContext lockTableElement(int i) {
			return getRuleContext(LockTableElementContext.class,i);
		}
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TerminalNode TABLES() { return getToken(MariaDBParser.TABLES, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLockTables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLockTables(this);
		}
	}

	public final LockTablesContext lockTables() throws RecognitionException {
		LockTablesContext _localctx = new LockTablesContext(_ctx, getState());
		enterRule(_localctx, 320, RULE_lockTables);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4462);
			match(LOCK);
			setState(4463);
			_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(4464);
			lockTableElement();
			setState(4469);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4465);
				match(COMMA);
				setState(4466);
				lockTableElement();
				}
				}
				setState(4471);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(4473);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOWAIT || _la==WAIT) {
				{
				setState(4472);
				waitNowaitClause();
				}
			}

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

	public static class UnlockTablesContext extends ParserRuleContext {
		public TerminalNode UNLOCK() { return getToken(MariaDBParser.UNLOCK, 0); }
		public TerminalNode TABLES() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUnlockTables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUnlockTables(this);
		}
	}

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

	public static class SetAutocommitStatementContext extends ParserRuleContext {
		public Token autocommitValue;
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode AUTOCOMMIT() { return getToken(MariaDBParser.AUTOCOMMIT, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetAutocommitStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetAutocommitStatement(this);
		}
	}

	public final SetAutocommitStatementContext setAutocommitStatement() throws RecognitionException {
		SetAutocommitStatementContext _localctx = new SetAutocommitStatementContext(_ctx, getState());
		enterRule(_localctx, 324, RULE_setAutocommitStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4478);
			match(SET);
			setState(4479);
			match(AUTOCOMMIT);
			setState(4480);
			match(EQUAL_SYMBOL);
			setState(4481);
			((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;
	}

	public static class SetTransactionStatementContext extends ParserRuleContext {
		public Token transactionContext;
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode TRANSACTION() { return getToken(MariaDBParser.TRANSACTION, 0); }
		public List transactionOption() {
			return getRuleContexts(TransactionOptionContext.class);
		}
		public TransactionOptionContext transactionOption(int i) {
			return getRuleContext(TransactionOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode GLOBAL() { return getToken(MariaDBParser.GLOBAL, 0); }
		public TerminalNode SESSION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetTransactionStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetTransactionStatement(this);
		}
	}

	public final SetTransactionStatementContext setTransactionStatement() throws RecognitionException {
		SetTransactionStatementContext _localctx = new SetTransactionStatementContext(_ctx, getState());
		enterRule(_localctx, 326, RULE_setTransactionStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4483);
			match(SET);
			setState(4485);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==GLOBAL || _la==SESSION) {
				{
				setState(4484);
				((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(4487);
			match(TRANSACTION);
			setState(4488);
			transactionOption();
			setState(4493);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4489);
				match(COMMA);
				setState(4490);
				transactionOption();
				}
				}
				setState(4495);
				_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;
	}

	public static class TransactionModeContext extends ParserRuleContext {
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public TerminalNode CONSISTENT() { return getToken(MariaDBParser.CONSISTENT, 0); }
		public TerminalNode SNAPSHOT() { return getToken(MariaDBParser.SNAPSHOT, 0); }
		public TerminalNode READ() { return getToken(MariaDBParser.READ, 0); }
		public TerminalNode WRITE() { return getToken(MariaDBParser.WRITE, 0); }
		public TerminalNode ONLY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTransactionMode(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTransactionMode(this);
		}
	}

	public final TransactionModeContext transactionMode() throws RecognitionException {
		TransactionModeContext _localctx = new TransactionModeContext(_ctx, getState());
		enterRule(_localctx, 328, RULE_transactionMode);
		try {
			setState(4503);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,674,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4496);
				match(WITH);
				setState(4497);
				match(CONSISTENT);
				setState(4498);
				match(SNAPSHOT);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4499);
				match(READ);
				setState(4500);
				match(WRITE);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(4501);
				match(READ);
				setState(4502);
				match(ONLY);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLockTableElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLockTableElement(this);
		}
	}

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

				setState(4509);
				uid();
				}
			}

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

	public static class LockActionContext extends ParserRuleContext {
		public TerminalNode READ() { return getToken(MariaDBParser.READ, 0); }
		public TerminalNode LOCAL() { return getToken(MariaDBParser.LOCAL, 0); }
		public TerminalNode WRITE() { return getToken(MariaDBParser.WRITE, 0); }
		public TerminalNode LOW_PRIORITY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLockAction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLockAction(this);
		}
	}

	public final LockActionContext lockAction() throws RecognitionException {
		LockActionContext _localctx = new LockActionContext(_ctx, getState());
		enterRule(_localctx, 332, RULE_lockAction);
		int _la;
		try {
			setState(4522);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case READ:
				enterOuterAlt(_localctx, 1);
				{
				setState(4514);
				match(READ);
				setState(4516);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LOCAL) {
					{
					setState(4515);
					match(LOCAL);
					}
				}

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

				setState(4521);
				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;
	}

	public static class TransactionOptionContext extends ParserRuleContext {
		public TerminalNode ISOLATION() { return getToken(MariaDBParser.ISOLATION, 0); }
		public TerminalNode LEVEL() { return getToken(MariaDBParser.LEVEL, 0); }
		public TransactionLevelContext transactionLevel() {
			return getRuleContext(TransactionLevelContext.class,0);
		}
		public TerminalNode READ() { return getToken(MariaDBParser.READ, 0); }
		public TerminalNode WRITE() { return getToken(MariaDBParser.WRITE, 0); }
		public TerminalNode ONLY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTransactionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTransactionOption(this);
		}
	}

	public final TransactionOptionContext transactionOption() throws RecognitionException {
		TransactionOptionContext _localctx = new TransactionOptionContext(_ctx, getState());
		enterRule(_localctx, 334, RULE_transactionOption);
		try {
			setState(4531);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,680,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4524);
				match(ISOLATION);
				setState(4525);
				match(LEVEL);
				setState(4526);
				transactionLevel();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4527);
				match(READ);
				setState(4528);
				match(WRITE);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(4529);
				match(READ);
				setState(4530);
				match(ONLY);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class TransactionLevelContext extends ParserRuleContext {
		public TerminalNode REPEATABLE() { return getToken(MariaDBParser.REPEATABLE, 0); }
		public TerminalNode READ() { return getToken(MariaDBParser.READ, 0); }
		public TerminalNode COMMITTED() { return getToken(MariaDBParser.COMMITTED, 0); }
		public TerminalNode UNCOMMITTED() { return getToken(MariaDBParser.UNCOMMITTED, 0); }
		public TerminalNode SERIALIZABLE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTransactionLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTransactionLevel(this);
		}
	}

	public final TransactionLevelContext transactionLevel() throws RecognitionException {
		TransactionLevelContext _localctx = new TransactionLevelContext(_ctx, getState());
		enterRule(_localctx, 336, RULE_transactionLevel);
		try {
			setState(4540);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,681,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4533);
				match(REPEATABLE);
				setState(4534);
				match(READ);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4535);
				match(READ);
				setState(4536);
				match(COMMITTED);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(4537);
				match(READ);
				setState(4538);
				match(UNCOMMITTED);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(4539);
				match(SERIALIZABLE);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ChangeMasterContext extends ParserRuleContext {
		public TerminalNode CHANGE() { return getToken(MariaDBParser.CHANGE, 0); }
		public TerminalNode MASTER() { return getToken(MariaDBParser.MASTER, 0); }
		public TerminalNode TO() { return getToken(MariaDBParser.TO, 0); }
		public List masterOption() {
			return getRuleContexts(MasterOptionContext.class);
		}
		public MasterOptionContext masterOption(int i) {
			return getRuleContext(MasterOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterChangeMaster(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitChangeMaster(this);
		}
	}

	public final ChangeMasterContext changeMaster() throws RecognitionException {
		ChangeMasterContext _localctx = new ChangeMasterContext(_ctx, getState());
		enterRule(_localctx, 338, RULE_changeMaster);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4542);
			match(CHANGE);
			setState(4543);
			match(MASTER);
			setState(4544);
			match(TO);
			setState(4545);
			masterOption();
			setState(4550);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4546);
				match(COMMA);
				setState(4547);
				masterOption();
				}
				}
				setState(4552);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(4554);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FOR) {
				{
				setState(4553);
				channelOption();
				}
			}

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

	public static class ChangeReplicationFilterContext extends ParserRuleContext {
		public TerminalNode CHANGE() { return getToken(MariaDBParser.CHANGE, 0); }
		public TerminalNode REPLICATION() { return getToken(MariaDBParser.REPLICATION, 0); }
		public TerminalNode FILTER() { return getToken(MariaDBParser.FILTER, 0); }
		public List replicationFilter() {
			return getRuleContexts(ReplicationFilterContext.class);
		}
		public ReplicationFilterContext replicationFilter(int i) {
			return getRuleContext(ReplicationFilterContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterChangeReplicationFilter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitChangeReplicationFilter(this);
		}
	}

	public final ChangeReplicationFilterContext changeReplicationFilter() throws RecognitionException {
		ChangeReplicationFilterContext _localctx = new ChangeReplicationFilterContext(_ctx, getState());
		enterRule(_localctx, 340, RULE_changeReplicationFilter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4556);
			match(CHANGE);
			setState(4557);
			match(REPLICATION);
			setState(4558);
			match(FILTER);
			setState(4559);
			replicationFilter();
			setState(4564);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4560);
				match(COMMA);
				setState(4561);
				replicationFilter();
				}
				}
				setState(4566);
				_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;
	}

	public static class PurgeBinaryLogsContext extends ParserRuleContext {
		public Token purgeFormat;
		public Token fileName;
		public Token timeValue;
		public TerminalNode PURGE() { return getToken(MariaDBParser.PURGE, 0); }
		public TerminalNode LOGS() { return getToken(MariaDBParser.LOGS, 0); }
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public TerminalNode MASTER() { return getToken(MariaDBParser.MASTER, 0); }
		public TerminalNode TO() { return getToken(MariaDBParser.TO, 0); }
		public TerminalNode BEFORE() { return getToken(MariaDBParser.BEFORE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPurgeBinaryLogs(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPurgeBinaryLogs(this);
		}
	}

	public final PurgeBinaryLogsContext purgeBinaryLogs() throws RecognitionException {
		PurgeBinaryLogsContext _localctx = new PurgeBinaryLogsContext(_ctx, getState());
		enterRule(_localctx, 342, RULE_purgeBinaryLogs);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4567);
			match(PURGE);
			setState(4568);
			((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(4569);
			match(LOGS);
			setState(4574);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case TO:
				{
				setState(4570);
				match(TO);
				setState(4571);
				((PurgeBinaryLogsContext)_localctx).fileName = match(STRING_LITERAL);
				}
				break;
			case BEFORE:
				{
				setState(4572);
				match(BEFORE);
				setState(4573);
				((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;
	}

	public static class ResetMasterContext extends ParserRuleContext {
		public TerminalNode RESET() { return getToken(MariaDBParser.RESET, 0); }
		public TerminalNode MASTER() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterResetMaster(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitResetMaster(this);
		}
	}

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

	public static class ResetSlaveContext extends ParserRuleContext {
		public TerminalNode RESET() { return getToken(MariaDBParser.RESET, 0); }
		public TerminalNode SLAVE() { return getToken(MariaDBParser.SLAVE, 0); }
		public TerminalNode ALL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterResetSlave(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitResetSlave(this);
		}
	}

	public final ResetSlaveContext resetSlave() throws RecognitionException {
		ResetSlaveContext _localctx = new ResetSlaveContext(_ctx, getState());
		enterRule(_localctx, 346, RULE_resetSlave);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4579);
			match(RESET);
			setState(4580);
			match(SLAVE);
			setState(4582);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ALL) {
				{
				setState(4581);
				match(ALL);
				}
			}

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

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

	public static class StartSlaveContext extends ParserRuleContext {
		public TerminalNode START() { return getToken(MariaDBParser.START, 0); }
		public TerminalNode SLAVE() { return getToken(MariaDBParser.SLAVE, 0); }
		public List threadType() {
			return getRuleContexts(ThreadTypeContext.class);
		}
		public ThreadTypeContext threadType(int i) {
			return getRuleContext(ThreadTypeContext.class,i);
		}
		public TerminalNode UNTIL() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterStartSlave(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStartSlave(this);
		}
	}

	public final StartSlaveContext startSlave() throws RecognitionException {
		StartSlaveContext _localctx = new StartSlaveContext(_ctx, getState());
		enterRule(_localctx, 348, RULE_startSlave);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4587);
			match(START);
			setState(4588);
			match(SLAVE);
			setState(4597);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IO_THREAD || _la==SQL_THREAD) {
				{
				setState(4589);
				threadType();
				setState(4594);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4590);
					match(COMMA);
					setState(4591);
					threadType();
					}
					}
					setState(4596);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
			}

			setState(4601);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==UNTIL) {
				{
				setState(4599);
				match(UNTIL);
				setState(4600);
				untilOption();
				}
			}

			setState(4606);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DEFAULT_AUTH || _la==PASSWORD || _la==PLUGIN_DIR || _la==USER) {
				{
				{
				setState(4603);
				connectionOption();
				}
				}
				setState(4608);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(4610);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FOR) {
				{
				setState(4609);
				channelOption();
				}
			}

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

	public static class StopSlaveContext extends ParserRuleContext {
		public TerminalNode STOP() { return getToken(MariaDBParser.STOP, 0); }
		public TerminalNode SLAVE() { return getToken(MariaDBParser.SLAVE, 0); }
		public List threadType() {
			return getRuleContexts(ThreadTypeContext.class);
		}
		public ThreadTypeContext threadType(int i) {
			return getRuleContext(ThreadTypeContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterStopSlave(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStopSlave(this);
		}
	}

	public final StopSlaveContext stopSlave() throws RecognitionException {
		StopSlaveContext _localctx = new StopSlaveContext(_ctx, getState());
		enterRule(_localctx, 350, RULE_stopSlave);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4612);
			match(STOP);
			setState(4613);
			match(SLAVE);
			setState(4622);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IO_THREAD || _la==SQL_THREAD) {
				{
				setState(4614);
				threadType();
				setState(4619);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4615);
					match(COMMA);
					setState(4616);
					threadType();
					}
					}
					setState(4621);
					_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;
	}

	public static class StartGroupReplicationContext extends ParserRuleContext {
		public TerminalNode START() { return getToken(MariaDBParser.START, 0); }
		public TerminalNode GROUP_REPLICATION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterStartGroupReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStartGroupReplication(this);
		}
	}

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

	public static class StopGroupReplicationContext extends ParserRuleContext {
		public TerminalNode STOP() { return getToken(MariaDBParser.STOP, 0); }
		public TerminalNode GROUP_REPLICATION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterStopGroupReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStopGroupReplication(this);
		}
	}

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

	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);
		}
	}
	public static class MasterStringOptionContext extends MasterOptionContext {
		public StringMasterOptionContext stringMasterOption() {
			return getRuleContext(StringMasterOptionContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public MasterStringOptionContext(MasterOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterMasterStringOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMasterStringOption(this);
		}
	}
	public static class MasterRealOptionContext extends MasterOptionContext {
		public TerminalNode MASTER_HEARTBEAT_PERIOD() { return getToken(MariaDBParser.MASTER_HEARTBEAT_PERIOD, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode REAL_LITERAL() { return getToken(MariaDBParser.REAL_LITERAL, 0); }
		public MasterRealOptionContext(MasterOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterMasterRealOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMasterRealOption(this);
		}
	}
	public static class MasterBoolOptionContext extends MasterOptionContext {
		public Token boolVal;
		public BoolMasterOptionContext boolMasterOption() {
			return getRuleContext(BoolMasterOptionContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public MasterBoolOptionContext(MasterOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterMasterBoolOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMasterBoolOption(this);
		}
	}
	public static class MasterUidListOptionContext extends MasterOptionContext {
		public TerminalNode IGNORE_SERVER_IDS() { return getToken(MariaDBParser.IGNORE_SERVER_IDS, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public MasterUidListOptionContext(MasterOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterMasterUidListOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMasterUidListOption(this);
		}
	}
	public static class MasterDecimalOptionContext extends MasterOptionContext {
		public DecimalMasterOptionContext decimalMasterOption() {
			return getRuleContext(DecimalMasterOptionContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterMasterDecimalOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMasterDecimalOption(this);
		}
	}

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

				setState(4658);
				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;
	}

	public static class StringMasterOptionContext extends ParserRuleContext {
		public TerminalNode MASTER_BIND() { return getToken(MariaDBParser.MASTER_BIND, 0); }
		public TerminalNode MASTER_HOST() { return getToken(MariaDBParser.MASTER_HOST, 0); }
		public TerminalNode MASTER_USER() { return getToken(MariaDBParser.MASTER_USER, 0); }
		public TerminalNode MASTER_PASSWORD() { return getToken(MariaDBParser.MASTER_PASSWORD, 0); }
		public TerminalNode MASTER_LOG_FILE() { return getToken(MariaDBParser.MASTER_LOG_FILE, 0); }
		public TerminalNode RELAY_LOG_FILE() { return getToken(MariaDBParser.RELAY_LOG_FILE, 0); }
		public TerminalNode MASTER_SSL_CA() { return getToken(MariaDBParser.MASTER_SSL_CA, 0); }
		public TerminalNode MASTER_SSL_CAPATH() { return getToken(MariaDBParser.MASTER_SSL_CAPATH, 0); }
		public TerminalNode MASTER_SSL_CERT() { return getToken(MariaDBParser.MASTER_SSL_CERT, 0); }
		public TerminalNode MASTER_SSL_CRL() { return getToken(MariaDBParser.MASTER_SSL_CRL, 0); }
		public TerminalNode MASTER_SSL_CRLPATH() { return getToken(MariaDBParser.MASTER_SSL_CRLPATH, 0); }
		public TerminalNode MASTER_SSL_KEY() { return getToken(MariaDBParser.MASTER_SSL_KEY, 0); }
		public TerminalNode MASTER_SSL_CIPHER() { return getToken(MariaDBParser.MASTER_SSL_CIPHER, 0); }
		public TerminalNode MASTER_TLS_VERSION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterStringMasterOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStringMasterOption(this);
		}
	}

	public final StringMasterOptionContext stringMasterOption() throws RecognitionException {
		StringMasterOptionContext _localctx = new StringMasterOptionContext(_ctx, getState());
		enterRule(_localctx, 358, RULE_stringMasterOption);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4661);
			_la = _input.LA(1);
			if ( !(_la==MASTER_BIND || ((((_la - 483)) & ~0x3f) == 0 && ((1L << (_la - 483)) & ((1L << (MASTER_HOST - 483)) | (1L << (MASTER_LOG_FILE - 483)) | (1L << (MASTER_PASSWORD - 483)) | (1L << (MASTER_SSL_CA - 483)) | (1L << (MASTER_SSL_CAPATH - 483)) | (1L << (MASTER_SSL_CERT - 483)) | (1L << (MASTER_SSL_CIPHER - 483)) | (1L << (MASTER_SSL_CRL - 483)) | (1L << (MASTER_SSL_CRLPATH - 483)) | (1L << (MASTER_SSL_KEY - 483)) | (1L << (MASTER_TLS_VERSION - 483)) | (1L << (MASTER_USER - 483)))) != 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;
	}

	public static class DecimalMasterOptionContext extends ParserRuleContext {
		public TerminalNode MASTER_PORT() { return getToken(MariaDBParser.MASTER_PORT, 0); }
		public TerminalNode MASTER_CONNECT_RETRY() { return getToken(MariaDBParser.MASTER_CONNECT_RETRY, 0); }
		public TerminalNode MASTER_RETRY_COUNT() { return getToken(MariaDBParser.MASTER_RETRY_COUNT, 0); }
		public TerminalNode MASTER_DELAY() { return getToken(MariaDBParser.MASTER_DELAY, 0); }
		public TerminalNode MASTER_LOG_POS() { return getToken(MariaDBParser.MASTER_LOG_POS, 0); }
		public TerminalNode RELAY_LOG_POS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDecimalMasterOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDecimalMasterOption(this);
		}
	}

	public final DecimalMasterOptionContext decimalMasterOption() throws RecognitionException {
		DecimalMasterOptionContext _localctx = new DecimalMasterOptionContext(_ctx, getState());
		enterRule(_localctx, 360, RULE_decimalMasterOption);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4663);
			_la = _input.LA(1);
			if ( !(((((_la - 480)) & ~0x3f) == 0 && ((1L << (_la - 480)) & ((1L << (MASTER_CONNECT_RETRY - 480)) | (1L << (MASTER_DELAY - 480)) | (1L << (MASTER_LOG_POS - 480)) | (1L << (MASTER_PORT - 480)) | (1L << (MASTER_RETRY_COUNT - 480)))) != 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;
	}

	public static class BoolMasterOptionContext extends ParserRuleContext {
		public TerminalNode MASTER_AUTO_POSITION() { return getToken(MariaDBParser.MASTER_AUTO_POSITION, 0); }
		public TerminalNode MASTER_SSL() { return getToken(MariaDBParser.MASTER_SSL, 0); }
		public TerminalNode MASTER_SSL_VERIFY_SERVER_CERT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterBoolMasterOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitBoolMasterOption(this);
		}
	}

	public final BoolMasterOptionContext boolMasterOption() throws RecognitionException {
		BoolMasterOptionContext _localctx = new BoolMasterOptionContext(_ctx, getState());
		enterRule(_localctx, 362, RULE_boolMasterOption);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4665);
			_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;
	}

	public static class ChannelOptionContext extends ParserRuleContext {
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode CHANNEL() { return getToken(MariaDBParser.CHANNEL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterChannelOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitChannelOption(this);
		}
	}

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

	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);
		}
	}
	public static class WildIgnoreTableReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_WILD_IGNORE_TABLE() { return getToken(MariaDBParser.REPLICATE_WILD_IGNORE_TABLE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public SimpleStringsContext simpleStrings() {
			return getRuleContext(SimpleStringsContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public WildIgnoreTableReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterWildIgnoreTableReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitWildIgnoreTableReplication(this);
		}
	}
	public static class DoTableReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_DO_TABLE() { return getToken(MariaDBParser.REPLICATE_DO_TABLE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public DoTableReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterDoTableReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDoTableReplication(this);
		}
	}
	public static class IgnoreTableReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_IGNORE_TABLE() { return getToken(MariaDBParser.REPLICATE_IGNORE_TABLE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public IgnoreTableReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterIgnoreTableReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIgnoreTableReplication(this);
		}
	}
	public static class RewriteDbReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_REWRITE_DB() { return getToken(MariaDBParser.REPLICATE_REWRITE_DB, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public RewriteDbReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterRewriteDbReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRewriteDbReplication(this);
		}
	}
	public static class DoDbReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_DO_DB() { return getToken(MariaDBParser.REPLICATE_DO_DB, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public DoDbReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterDoDbReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDoDbReplication(this);
		}
	}
	public static class IgnoreDbReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_IGNORE_DB() { return getToken(MariaDBParser.REPLICATE_IGNORE_DB, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public IgnoreDbReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterIgnoreDbReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIgnoreDbReplication(this);
		}
	}
	public static class WildDoTableReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_WILD_DO_TABLE() { return getToken(MariaDBParser.REPLICATE_WILD_DO_TABLE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public SimpleStringsContext simpleStrings() {
			return getRuleContext(SimpleStringsContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public WildDoTableReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterWildDoTableReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitWildDoTableReplication(this);
		}
	}

	public final ReplicationFilterContext replicationFilter() throws RecognitionException {
		ReplicationFilterContext _localctx = new ReplicationFilterContext(_ctx, getState());
		enterRule(_localctx, 366, RULE_replicationFilter);
		int _la;
		try {
			setState(4720);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REPLICATE_DO_DB:
				_localctx = new DoDbReplicationContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4671);
				match(REPLICATE_DO_DB);
				setState(4672);
				match(EQUAL_SYMBOL);
				setState(4673);
				match(LR_BRACKET);
				setState(4674);
				uidList();
				setState(4675);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_IGNORE_DB:
				_localctx = new IgnoreDbReplicationContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4677);
				match(REPLICATE_IGNORE_DB);
				setState(4678);
				match(EQUAL_SYMBOL);
				setState(4679);
				match(LR_BRACKET);
				setState(4680);
				uidList();
				setState(4681);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_DO_TABLE:
				_localctx = new DoTableReplicationContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4683);
				match(REPLICATE_DO_TABLE);
				setState(4684);
				match(EQUAL_SYMBOL);
				setState(4685);
				match(LR_BRACKET);
				setState(4686);
				tables();
				setState(4687);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_IGNORE_TABLE:
				_localctx = new IgnoreTableReplicationContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(4689);
				match(REPLICATE_IGNORE_TABLE);
				setState(4690);
				match(EQUAL_SYMBOL);
				setState(4691);
				match(LR_BRACKET);
				setState(4692);
				tables();
				setState(4693);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_WILD_DO_TABLE:
				_localctx = new WildDoTableReplicationContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(4695);
				match(REPLICATE_WILD_DO_TABLE);
				setState(4696);
				match(EQUAL_SYMBOL);
				setState(4697);
				match(LR_BRACKET);
				setState(4698);
				simpleStrings();
				setState(4699);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_WILD_IGNORE_TABLE:
				_localctx = new WildIgnoreTableReplicationContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(4701);
				match(REPLICATE_WILD_IGNORE_TABLE);
				setState(4702);
				match(EQUAL_SYMBOL);
				setState(4703);
				match(LR_BRACKET);
				setState(4704);
				simpleStrings();
				setState(4705);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_REWRITE_DB:
				_localctx = new RewriteDbReplicationContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(4707);
				match(REPLICATE_REWRITE_DB);
				setState(4708);
				match(EQUAL_SYMBOL);
				setState(4709);
				match(LR_BRACKET);
				setState(4710);
				tablePair();
				setState(4715);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4711);
					match(COMMA);
					setState(4712);
					tablePair();
					}
					}
					setState(4717);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(4718);
				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;
	}

	public static class TablePairContext extends ParserRuleContext {
		public TableNameContext firstTable;
		public TableNameContext secondTable;
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode COMMA() { return getToken(MariaDBParser.COMMA, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTablePair(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTablePair(this);
		}
	}

	public final TablePairContext tablePair() throws RecognitionException {
		TablePairContext _localctx = new TablePairContext(_ctx, getState());
		enterRule(_localctx, 368, RULE_tablePair);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4722);
			match(LR_BRACKET);
			setState(4723);
			((TablePairContext)_localctx).firstTable = tableName();
			setState(4724);
			match(COMMA);
			setState(4725);
			((TablePairContext)_localctx).secondTable = tableName();
			setState(4726);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ThreadTypeContext extends ParserRuleContext {
		public TerminalNode IO_THREAD() { return getToken(MariaDBParser.IO_THREAD, 0); }
		public TerminalNode SQL_THREAD() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterThreadType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitThreadType(this);
		}
	}

	public final ThreadTypeContext threadType() throws RecognitionException {
		ThreadTypeContext _localctx = new ThreadTypeContext(_ctx, getState());
		enterRule(_localctx, 370, RULE_threadType);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4728);
			_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;
	}

	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);
		}
	}
	public static class GtidsUntilOptionContext extends UntilOptionContext {
		public Token gtids;
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public GtuidSetContext gtuidSet() {
			return getRuleContext(GtuidSetContext.class,0);
		}
		public TerminalNode SQL_BEFORE_GTIDS() { return getToken(MariaDBParser.SQL_BEFORE_GTIDS, 0); }
		public TerminalNode SQL_AFTER_GTIDS() { return getToken(MariaDBParser.SQL_AFTER_GTIDS, 0); }
		public GtidsUntilOptionContext(UntilOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterGtidsUntilOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitGtidsUntilOption(this);
		}
	}
	public static class SqlGapsUntilOptionContext extends UntilOptionContext {
		public TerminalNode SQL_AFTER_MTS_GAPS() { return getToken(MariaDBParser.SQL_AFTER_MTS_GAPS, 0); }
		public SqlGapsUntilOptionContext(UntilOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSqlGapsUntilOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSqlGapsUntilOption(this);
		}
	}
	public static class MasterLogUntilOptionContext extends UntilOptionContext {
		public TerminalNode MASTER_LOG_FILE() { return getToken(MariaDBParser.MASTER_LOG_FILE, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.EQUAL_SYMBOL, i);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode COMMA() { return getToken(MariaDBParser.COMMA, 0); }
		public TerminalNode MASTER_LOG_POS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterMasterLogUntilOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMasterLogUntilOption(this);
		}
	}
	public static class RelayLogUntilOptionContext extends UntilOptionContext {
		public TerminalNode RELAY_LOG_FILE() { return getToken(MariaDBParser.RELAY_LOG_FILE, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.EQUAL_SYMBOL, i);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode COMMA() { return getToken(MariaDBParser.COMMA, 0); }
		public TerminalNode RELAY_LOG_POS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRelayLogUntilOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRelayLogUntilOption(this);
		}
	}

	public final UntilOptionContext untilOption() throws RecognitionException {
		UntilOptionContext _localctx = new UntilOptionContext(_ctx, getState());
		enterRule(_localctx, 372, RULE_untilOption);
		int _la;
		try {
			setState(4748);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SQL_AFTER_GTIDS:
			case SQL_BEFORE_GTIDS:
				_localctx = new GtidsUntilOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4730);
				((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(4731);
				match(EQUAL_SYMBOL);
				setState(4732);
				gtuidSet();
				}
				break;
			case MASTER_LOG_FILE:
				_localctx = new MasterLogUntilOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4733);
				match(MASTER_LOG_FILE);
				setState(4734);
				match(EQUAL_SYMBOL);
				setState(4735);
				match(STRING_LITERAL);
				setState(4736);
				match(COMMA);
				setState(4737);
				match(MASTER_LOG_POS);
				setState(4738);
				match(EQUAL_SYMBOL);
				setState(4739);
				decimalLiteral();
				}
				break;
			case RELAY_LOG_FILE:
				_localctx = new RelayLogUntilOptionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4740);
				match(RELAY_LOG_FILE);
				setState(4741);
				match(EQUAL_SYMBOL);
				setState(4742);
				match(STRING_LITERAL);
				setState(4743);
				match(COMMA);
				setState(4744);
				match(RELAY_LOG_POS);
				setState(4745);
				match(EQUAL_SYMBOL);
				setState(4746);
				decimalLiteral();
				}
				break;
			case SQL_AFTER_MTS_GAPS:
				_localctx = new SqlGapsUntilOptionContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(4747);
				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;
	}

	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);
		}
	}
	public static class PluginDirConnectionOptionContext extends ConnectionOptionContext {
		public Token conOptPluginDir;
		public TerminalNode PLUGIN_DIR() { return getToken(MariaDBParser.PLUGIN_DIR, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public PluginDirConnectionOptionContext(ConnectionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPluginDirConnectionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPluginDirConnectionOption(this);
		}
	}
	public static class UserConnectionOptionContext extends ConnectionOptionContext {
		public Token conOptUser;
		public TerminalNode USER() { return getToken(MariaDBParser.USER, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public UserConnectionOptionContext(ConnectionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterUserConnectionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUserConnectionOption(this);
		}
	}
	public static class DefaultAuthConnectionOptionContext extends ConnectionOptionContext {
		public Token conOptDefAuth;
		public TerminalNode DEFAULT_AUTH() { return getToken(MariaDBParser.DEFAULT_AUTH, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public DefaultAuthConnectionOptionContext(ConnectionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterDefaultAuthConnectionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDefaultAuthConnectionOption(this);
		}
	}
	public static class PasswordConnectionOptionContext extends ConnectionOptionContext {
		public Token conOptPassword;
		public TerminalNode PASSWORD() { return getToken(MariaDBParser.PASSWORD, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public PasswordConnectionOptionContext(ConnectionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPasswordConnectionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPasswordConnectionOption(this);
		}
	}

	public final ConnectionOptionContext connectionOption() throws RecognitionException {
		ConnectionOptionContext _localctx = new ConnectionOptionContext(_ctx, getState());
		enterRule(_localctx, 374, RULE_connectionOption);
		try {
			setState(4762);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case USER:
				_localctx = new UserConnectionOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4750);
				match(USER);
				setState(4751);
				match(EQUAL_SYMBOL);
				setState(4752);
				((UserConnectionOptionContext)_localctx).conOptUser = match(STRING_LITERAL);
				}
				break;
			case PASSWORD:
				_localctx = new PasswordConnectionOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4753);
				match(PASSWORD);
				setState(4754);
				match(EQUAL_SYMBOL);
				setState(4755);
				((PasswordConnectionOptionContext)_localctx).conOptPassword = match(STRING_LITERAL);
				}
				break;
			case DEFAULT_AUTH:
				_localctx = new DefaultAuthConnectionOptionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4756);
				match(DEFAULT_AUTH);
				setState(4757);
				match(EQUAL_SYMBOL);
				setState(4758);
				((DefaultAuthConnectionOptionContext)_localctx).conOptDefAuth = match(STRING_LITERAL);
				}
				break;
			case PLUGIN_DIR:
				_localctx = new PluginDirConnectionOptionContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(4759);
				match(PLUGIN_DIR);
				setState(4760);
				match(EQUAL_SYMBOL);
				setState(4761);
				((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;
	}

	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterGtuidSet(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitGtuidSet(this);
		}
	}

	public final GtuidSetContext gtuidSet() throws RecognitionException {
		GtuidSetContext _localctx = new GtuidSetContext(_ctx, getState());
		enterRule(_localctx, 376, RULE_gtuidSet);
		int _la;
		try {
			setState(4773);
			_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(4764);
				uuidSet();
				setState(4769);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4765);
					match(COMMA);
					setState(4766);
					uuidSet();
					}
					}
					setState(4771);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case STRING_LITERAL:
				enterOuterAlt(_localctx, 2);
				{
				setState(4772);
				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;
	}

	public static class XaStartTransactionContext extends ParserRuleContext {
		public Token xaStart;
		public Token xaAction;
		public TerminalNode XA() { return getToken(MariaDBParser.XA, 0); }
		public XidContext xid() {
			return getRuleContext(XidContext.class,0);
		}
		public TerminalNode START() { return getToken(MariaDBParser.START, 0); }
		public TerminalNode BEGIN() { return getToken(MariaDBParser.BEGIN, 0); }
		public TerminalNode JOIN() { return getToken(MariaDBParser.JOIN, 0); }
		public TerminalNode RESUME() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterXaStartTransaction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitXaStartTransaction(this);
		}
	}

	public final XaStartTransactionContext xaStartTransaction() throws RecognitionException {
		XaStartTransactionContext _localctx = new XaStartTransactionContext(_ctx, getState());
		enterRule(_localctx, 378, RULE_xaStartTransaction);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4775);
			match(XA);
			setState(4776);
			((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(4777);
			xid();
			setState(4779);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==JOIN || _la==RESUME) {
				{
				setState(4778);
				((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;
	}

	public static class XaEndTransactionContext extends ParserRuleContext {
		public TerminalNode XA() { return getToken(MariaDBParser.XA, 0); }
		public TerminalNode END() { return getToken(MariaDBParser.END, 0); }
		public XidContext xid() {
			return getRuleContext(XidContext.class,0);
		}
		public TerminalNode SUSPEND() { return getToken(MariaDBParser.SUSPEND, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode MIGRATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterXaEndTransaction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitXaEndTransaction(this);
		}
	}

	public final XaEndTransactionContext xaEndTransaction() throws RecognitionException {
		XaEndTransactionContext _localctx = new XaEndTransactionContext(_ctx, getState());
		enterRule(_localctx, 380, RULE_xaEndTransaction);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4781);
			match(XA);
			setState(4782);
			match(END);
			setState(4783);
			xid();
			setState(4789);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==SUSPEND) {
				{
				setState(4784);
				match(SUSPEND);
				setState(4787);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(4785);
					match(FOR);
					setState(4786);
					match(MIGRATE);
					}
				}

				}
			}

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

	public static class XaPrepareStatementContext extends ParserRuleContext {
		public TerminalNode XA() { return getToken(MariaDBParser.XA, 0); }
		public TerminalNode PREPARE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterXaPrepareStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitXaPrepareStatement(this);
		}
	}

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

	public static class XaCommitWorkContext extends ParserRuleContext {
		public TerminalNode XA() { return getToken(MariaDBParser.XA, 0); }
		public TerminalNode COMMIT() { return getToken(MariaDBParser.COMMIT, 0); }
		public XidContext xid() {
			return getRuleContext(XidContext.class,0);
		}
		public TerminalNode ONE() { return getToken(MariaDBParser.ONE, 0); }
		public TerminalNode PHASE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterXaCommitWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitXaCommitWork(this);
		}
	}

	public final XaCommitWorkContext xaCommitWork() throws RecognitionException {
		XaCommitWorkContext _localctx = new XaCommitWorkContext(_ctx, getState());
		enterRule(_localctx, 384, RULE_xaCommitWork);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4795);
			match(XA);
			setState(4796);
			match(COMMIT);
			setState(4797);
			xid();
			setState(4800);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ONE) {
				{
				setState(4798);
				match(ONE);
				setState(4799);
				match(PHASE);
				}
			}

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

	public static class XaRollbackWorkContext extends ParserRuleContext {
		public TerminalNode XA() { return getToken(MariaDBParser.XA, 0); }
		public TerminalNode ROLLBACK() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterXaRollbackWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitXaRollbackWork(this);
		}
	}

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

	public static class XaRecoverWorkContext extends ParserRuleContext {
		public TerminalNode XA() { return getToken(MariaDBParser.XA, 0); }
		public TerminalNode RECOVER() { return getToken(MariaDBParser.RECOVER, 0); }
		public TerminalNode CONVERT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterXaRecoverWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitXaRecoverWork(this);
		}
	}

	public final XaRecoverWorkContext xaRecoverWork() throws RecognitionException {
		XaRecoverWorkContext _localctx = new XaRecoverWorkContext(_ctx, getState());
		enterRule(_localctx, 388, RULE_xaRecoverWork);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4806);
			match(XA);
			setState(4807);
			match(RECOVER);
			setState(4810);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CONVERT) {
				{
				setState(4808);
				match(CONVERT);
				setState(4809);
				xid();
				}
			}

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

	public static class PrepareStatementContext extends ParserRuleContext {
		public Token query;
		public Token variable;
		public TerminalNode PREPARE() { return getToken(MariaDBParser.PREPARE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode LOCAL_ID() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPrepareStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPrepareStatement(this);
		}
	}

	public final PrepareStatementContext prepareStatement() throws RecognitionException {
		PrepareStatementContext _localctx = new PrepareStatementContext(_ctx, getState());
		enterRule(_localctx, 390, RULE_prepareStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4812);
			match(PREPARE);
			setState(4813);
			uid();
			setState(4814);
			match(FROM);
			setState(4817);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case STRING_LITERAL:
				{
				setState(4815);
				((PrepareStatementContext)_localctx).query = match(STRING_LITERAL);
				}
				break;
			case LOCAL_ID:
				{
				setState(4816);
				((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;
	}

	public static class ExecuteStatementContext extends ParserRuleContext {
		public TerminalNode EXECUTE() { return getToken(MariaDBParser.EXECUTE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode USING() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterExecuteStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitExecuteStatement(this);
		}
	}

	public final ExecuteStatementContext executeStatement() throws RecognitionException {
		ExecuteStatementContext _localctx = new ExecuteStatementContext(_ctx, getState());
		enterRule(_localctx, 392, RULE_executeStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4819);
			match(EXECUTE);
			setState(4820);
			uid();
			setState(4823);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==USING) {
				{
				setState(4821);
				match(USING);
				setState(4822);
				userVariables();
				}
			}

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

	public static class DeallocatePrepareContext extends ParserRuleContext {
		public Token dropFormat;
		public TerminalNode PREPARE() { return getToken(MariaDBParser.PREPARE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DEALLOCATE() { return getToken(MariaDBParser.DEALLOCATE, 0); }
		public TerminalNode DROP() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDeallocatePrepare(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDeallocatePrepare(this);
		}
	}

	public final DeallocatePrepareContext deallocatePrepare() throws RecognitionException {
		DeallocatePrepareContext _localctx = new DeallocatePrepareContext(_ctx, getState());
		enterRule(_localctx, 394, RULE_deallocatePrepare);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4825);
			((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(4826);
			match(PREPARE);
			setState(4827);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRoutineBody(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRoutineBody(this);
		}
	}

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

	public static class BlockStatementContext extends ParserRuleContext {
		public TerminalNode BEGIN() { return getToken(MariaDBParser.BEGIN, 0); }
		public TerminalNode END() { return getToken(MariaDBParser.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(MariaDBParser.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(MariaDBParser.SEMI); }
		public TerminalNode SEMI(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterBlockStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitBlockStatement(this);
		}
	}

	public final BlockStatementContext blockStatement() throws RecognitionException {
		BlockStatementContext _localctx = new BlockStatementContext(_ctx, getState());
		enterRule(_localctx, 398, RULE_blockStatement);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4836);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,712,_ctx) ) {
			case 1:
				{
				setState(4833);
				uid();
				setState(4834);
				match(COLON_SYMB);
				}
				break;
			}
			setState(4838);
			match(BEGIN);
			setState(4877);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,718,_ctx) ) {
			case 1:
				{
				setState(4844);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,713,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(4839);
						declareVariable();
						setState(4840);
						match(SEMI);
						}
						} 
					}
					setState(4846);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,713,_ctx);
				}
				setState(4852);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,714,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(4847);
						declareCondition();
						setState(4848);
						match(SEMI);
						}
						} 
					}
					setState(4854);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,714,_ctx);
				}
				setState(4860);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,715,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(4855);
						declareCursor();
						setState(4856);
						match(SEMI);
						}
						} 
					}
					setState(4862);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,715,_ctx);
				}
				setState(4868);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DECLARE) {
					{
					{
					setState(4863);
					declareHandler();
					setState(4864);
					match(SEMI);
					}
					}
					setState(4870);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(4874);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,717,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(4871);
						procedureSqlStatement();
						}
						} 
					}
					setState(4876);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,717,_ctx);
				}
				}
				break;
			}
			setState(4879);
			match(END);
			setState(4881);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,719,_ctx) ) {
			case 1:
				{
				setState(4880);
				uid();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CaseStatementContext extends ParserRuleContext {
		public List CASE() { return getTokens(MariaDBParser.CASE); }
		public TerminalNode CASE(int i) {
			return getToken(MariaDBParser.CASE, i);
		}
		public TerminalNode END() { return getToken(MariaDBParser.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(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCaseStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCaseStatement(this);
		}
	}

	public final CaseStatementContext caseStatement() throws RecognitionException {
		CaseStatementContext _localctx = new CaseStatementContext(_ctx, getState());
		enterRule(_localctx, 400, RULE_caseStatement);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4883);
			match(CASE);
			setState(4886);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,720,_ctx) ) {
			case 1:
				{
				setState(4884);
				uid();
				}
				break;
			case 2:
				{
				setState(4885);
				expression(0);
				}
				break;
			}
			setState(4889); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(4888);
				caseAlternative();
				}
				}
				setState(4891); 
				_errHandler.sync(this);
				_la = _input.LA(1);
			} while ( _la==WHEN );
			setState(4899);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ELSE) {
				{
				setState(4893);
				match(ELSE);
				setState(4895); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(4894);
						procedureSqlStatement();
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(4897); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,722,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				}
			}

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

	public static class IfStatementContext extends ParserRuleContext {
		public ProcedureSqlStatementContext procedureSqlStatement;
		public List thenStatements = new ArrayList();
		public List elseStatements = new ArrayList();
		public List IF() { return getTokens(MariaDBParser.IF); }
		public TerminalNode IF(int i) {
			return getToken(MariaDBParser.IF, i);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode THEN() { return getToken(MariaDBParser.THEN, 0); }
		public TerminalNode END() { return getToken(MariaDBParser.END, 0); }
		public List elifAlternative() {
			return getRuleContexts(ElifAlternativeContext.class);
		}
		public ElifAlternativeContext elifAlternative(int i) {
			return getRuleContext(ElifAlternativeContext.class,i);
		}
		public TerminalNode ELSE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIfStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIfStatement(this);
		}
	}

	public final IfStatementContext ifStatement() throws RecognitionException {
		IfStatementContext _localctx = new IfStatementContext(_ctx, getState());
		enterRule(_localctx, 402, RULE_ifStatement);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4904);
			match(IF);
			setState(4905);
			expression(0);
			setState(4906);
			match(THEN);
			setState(4908); 
			_errHandler.sync(this);
			_alt = 1;
			do {
				switch (_alt) {
				case 1:
					{
					{
					setState(4907);
					((IfStatementContext)_localctx).procedureSqlStatement = procedureSqlStatement();
					((IfStatementContext)_localctx).thenStatements.add(((IfStatementContext)_localctx).procedureSqlStatement);
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(4910); 
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,724,_ctx);
			} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
			setState(4915);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==ELSEIF) {
				{
				{
				setState(4912);
				elifAlternative();
				}
				}
				setState(4917);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(4924);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ELSE) {
				{
				setState(4918);
				match(ELSE);
				setState(4920); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(4919);
						((IfStatementContext)_localctx).procedureSqlStatement = procedureSqlStatement();
						((IfStatementContext)_localctx).elseStatements.add(((IfStatementContext)_localctx).procedureSqlStatement);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(4922); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,726,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				}
			}

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

	public static class IterateStatementContext extends ParserRuleContext {
		public TerminalNode ITERATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIterateStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIterateStatement(this);
		}
	}

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

	public static class LeaveStatementContext extends ParserRuleContext {
		public TerminalNode LEAVE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLeaveStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLeaveStatement(this);
		}
	}

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

	public static class LoopStatementContext extends ParserRuleContext {
		public List LOOP() { return getTokens(MariaDBParser.LOOP); }
		public TerminalNode LOOP(int i) {
			return getToken(MariaDBParser.LOOP, i);
		}
		public TerminalNode END() { return getToken(MariaDBParser.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(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLoopStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLoopStatement(this);
		}
	}

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

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

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

	public static class RepeatStatementContext extends ParserRuleContext {
		public List REPEAT() { return getTokens(MariaDBParser.REPEAT); }
		public TerminalNode REPEAT(int i) {
			return getToken(MariaDBParser.REPEAT, i);
		}
		public TerminalNode UNTIL() { return getToken(MariaDBParser.UNTIL, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode END() { return getToken(MariaDBParser.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(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRepeatStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRepeatStatement(this);
		}
	}

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

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

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

	public static class ReturnStatementContext extends ParserRuleContext {
		public TerminalNode RETURN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterReturnStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitReturnStatement(this);
		}
	}

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

	public static class WhileStatementContext extends ParserRuleContext {
		public List WHILE() { return getTokens(MariaDBParser.WHILE); }
		public TerminalNode WHILE(int i) {
			return getToken(MariaDBParser.WHILE, i);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode DO() { return getToken(MariaDBParser.DO, 0); }
		public TerminalNode END() { return getToken(MariaDBParser.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(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterWhileStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitWhileStatement(this);
		}
	}

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

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

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

	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);
		}
	}
	public static class CloseCursorContext extends CursorStatementContext {
		public TerminalNode CLOSE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCloseCursor(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCloseCursor(this);
		}
	}
	public static class OpenCursorContext extends CursorStatementContext {
		public TerminalNode OPEN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterOpenCursor(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitOpenCursor(this);
		}
	}
	public static class FetchCursorContext extends CursorStatementContext {
		public TerminalNode FETCH() { return getToken(MariaDBParser.FETCH, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public TerminalNode NEXT() { return getToken(MariaDBParser.NEXT, 0); }
		public FetchCursorContext(CursorStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterFetchCursor(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFetchCursor(this);
		}
	}

	public final CursorStatementContext cursorStatement() throws RecognitionException {
		CursorStatementContext _localctx = new CursorStatementContext(_ctx, getState());
		enterRule(_localctx, 416, RULE_cursorStatement);
		int _la;
		try {
			setState(5005);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CLOSE:
				_localctx = new CloseCursorContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4990);
				match(CLOSE);
				setState(4991);
				uid();
				}
				break;
			case FETCH:
				_localctx = new FetchCursorContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4992);
				match(FETCH);
				setState(4997);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,738,_ctx) ) {
				case 1:
					{
					setState(4994);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==NEXT) {
						{
						setState(4993);
						match(NEXT);
						}
					}

					setState(4996);
					match(FROM);
					}
					break;
				}
				setState(4999);
				uid();
				setState(5000);
				match(INTO);
				setState(5001);
				uidList();
				}
				break;
			case OPEN:
				_localctx = new OpenCursorContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5003);
				match(OPEN);
				setState(5004);
				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;
	}

	public static class DeclareVariableContext extends ParserRuleContext {
		public TerminalNode DECLARE() { return getToken(MariaDBParser.DECLARE, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public DataTypeContext dataType() {
			return getRuleContext(DataTypeContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDeclareVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDeclareVariable(this);
		}
	}

	public final DeclareVariableContext declareVariable() throws RecognitionException {
		DeclareVariableContext _localctx = new DeclareVariableContext(_ctx, getState());
		enterRule(_localctx, 418, RULE_declareVariable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5007);
			match(DECLARE);
			setState(5008);
			uidList();
			setState(5009);
			dataType();
			setState(5012);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFAULT) {
				{
				setState(5010);
				match(DEFAULT);
				setState(5011);
				expression(0);
				}
			}

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

	public static class DeclareConditionContext extends ParserRuleContext {
		public TerminalNode DECLARE() { return getToken(MariaDBParser.DECLARE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode CONDITION() { return getToken(MariaDBParser.CONDITION, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode SQLSTATE() { return getToken(MariaDBParser.SQLSTATE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode VALUE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDeclareCondition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDeclareCondition(this);
		}
	}

	public final DeclareConditionContext declareCondition() throws RecognitionException {
		DeclareConditionContext _localctx = new DeclareConditionContext(_ctx, getState());
		enterRule(_localctx, 420, RULE_declareCondition);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5014);
			match(DECLARE);
			setState(5015);
			uid();
			setState(5016);
			match(CONDITION);
			setState(5017);
			match(FOR);
			setState(5024);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ZERO_DECIMAL:
			case ONE_DECIMAL:
			case TWO_DECIMAL:
			case DECIMAL_LITERAL:
			case REAL_LITERAL:
				{
				setState(5018);
				decimalLiteral();
				}
				break;
			case SQLSTATE:
				{
				setState(5019);
				match(SQLSTATE);
				setState(5021);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VALUE) {
					{
					setState(5020);
					match(VALUE);
					}
				}

				setState(5023);
				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;
	}

	public static class DeclareCursorContext extends ParserRuleContext {
		public TerminalNode DECLARE() { return getToken(MariaDBParser.DECLARE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode CURSOR() { return getToken(MariaDBParser.CURSOR, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDeclareCursor(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDeclareCursor(this);
		}
	}

	public final DeclareCursorContext declareCursor() throws RecognitionException {
		DeclareCursorContext _localctx = new DeclareCursorContext(_ctx, getState());
		enterRule(_localctx, 422, RULE_declareCursor);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5026);
			match(DECLARE);
			setState(5027);
			uid();
			setState(5028);
			match(CURSOR);
			setState(5029);
			match(FOR);
			setState(5030);
			selectStatement();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DeclareHandlerContext extends ParserRuleContext {
		public Token handlerAction;
		public TerminalNode DECLARE() { return getToken(MariaDBParser.DECLARE, 0); }
		public TerminalNode HANDLER() { return getToken(MariaDBParser.HANDLER, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.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(MariaDBParser.CONTINUE, 0); }
		public TerminalNode EXIT() { return getToken(MariaDBParser.EXIT, 0); }
		public TerminalNode UNDO() { return getToken(MariaDBParser.UNDO, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDeclareHandler(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDeclareHandler(this);
		}
	}

	public final DeclareHandlerContext declareHandler() throws RecognitionException {
		DeclareHandlerContext _localctx = new DeclareHandlerContext(_ctx, getState());
		enterRule(_localctx, 424, RULE_declareHandler);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5032);
			match(DECLARE);
			setState(5033);
			((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(5034);
			match(HANDLER);
			setState(5035);
			match(FOR);
			setState(5036);
			handlerConditionValue();
			setState(5041);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(5037);
				match(COMMA);
				setState(5038);
				handlerConditionValue();
				}
				}
				setState(5043);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(5044);
			routineBody();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class HandlerConditionWarningContext extends HandlerConditionValueContext {
		public TerminalNode SQLWARNING() { return getToken(MariaDBParser.SQLWARNING, 0); }
		public HandlerConditionWarningContext(HandlerConditionValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerConditionWarning(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerConditionWarning(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerConditionCode(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerConditionCode(this);
		}
	}
	public static class HandlerConditionNotfoundContext extends HandlerConditionValueContext {
		public TerminalNode NOT() { return getToken(MariaDBParser.NOT, 0); }
		public TerminalNode FOUND() { return getToken(MariaDBParser.FOUND, 0); }
		public HandlerConditionNotfoundContext(HandlerConditionValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerConditionNotfound(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerConditionNotfound(this);
		}
	}
	public static class HandlerConditionStateContext extends HandlerConditionValueContext {
		public TerminalNode SQLSTATE() { return getToken(MariaDBParser.SQLSTATE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode VALUE() { return getToken(MariaDBParser.VALUE, 0); }
		public HandlerConditionStateContext(HandlerConditionValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerConditionState(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerConditionState(this);
		}
	}
	public static class HandlerConditionExceptionContext extends HandlerConditionValueContext {
		public TerminalNode SQLEXCEPTION() { return getToken(MariaDBParser.SQLEXCEPTION, 0); }
		public HandlerConditionExceptionContext(HandlerConditionValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerConditionException(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerConditionException(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHandlerConditionName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHandlerConditionName(this);
		}
	}

	public final HandlerConditionValueContext handlerConditionValue() throws RecognitionException {
		HandlerConditionValueContext _localctx = new HandlerConditionValueContext(_ctx, getState());
		enterRule(_localctx, 426, RULE_handlerConditionValue);
		int _la;
		try {
			setState(5057);
			_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(5046);
				decimalLiteral();
				}
				break;
			case SQLSTATE:
				_localctx = new HandlerConditionStateContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5047);
				match(SQLSTATE);
				setState(5049);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VALUE) {
					{
					setState(5048);
					match(VALUE);
					}
				}

				setState(5051);
				match(STRING_LITERAL);
				}
				break;
			case ATTRIBUTE:
			case BODY:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_ROLE:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case LOCKED:
			case MAXVALUE:
			case MINVALUE:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case PACKAGE:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_:
			case STACKED:
			case STATEMENT:
			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 CYCLE:
			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 ENCRYPTED:
			case ENCRYPTION:
			case ENCRYPTION_KEY_ID:
			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 INCREMENT:
			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 LOCALES:
			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 NOCACHE:
			case NOCOPY:
			case NOCYCLE:
			case NOMAXVALUE:
			case NOMINVALUE:
			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 QUERY_RESPONSE_TIME:
			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 RESTART:
			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 SEQUENCE:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLAVES:
			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 TYPES:
			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 WSREP_MEMBERSHIP:
			case WSREP_STATUS:
			case X509:
			case XA:
			case XML:
			case YES:
			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 USER_STATISTICS:
			case CLIENT_STATISTICS:
			case INDEX_STATISTICS:
			case TABLE_STATISTICS:
			case ADMIN:
			case AUDIT_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_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_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 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 VIA:
			case LASTVAL:
			case NEXTVAL:
			case SETVAL:
			case PREVIOUS:
			case PERSISTENT:
			case BINLOG_MONITOR:
			case BINLOG_REPLAY:
			case FEDERATED_ADMIN:
			case READ_ONLY_ADMIN:
			case REPLICA:
			case REPLICAS:
			case REPLICATION_MASTER_ADMIN:
			case MONITOR:
			case READ_ONLY:
			case REPLAY:
			case MOD:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				_localctx = new HandlerConditionNameContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5052);
				uid();
				}
				break;
			case SQLWARNING:
				_localctx = new HandlerConditionWarningContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(5053);
				match(SQLWARNING);
				}
				break;
			case NOT:
				_localctx = new HandlerConditionNotfoundContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(5054);
				match(NOT);
				setState(5055);
				match(FOUND);
				}
				break;
			case SQLEXCEPTION:
				_localctx = new HandlerConditionExceptionContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(5056);
				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;
	}

	public static class ProcedureSqlStatementContext extends ParserRuleContext {
		public TerminalNode SEMI() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterProcedureSqlStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitProcedureSqlStatement(this);
		}
	}

	public final ProcedureSqlStatementContext procedureSqlStatement() throws RecognitionException {
		ProcedureSqlStatementContext _localctx = new ProcedureSqlStatementContext(_ctx, getState());
		enterRule(_localctx, 428, RULE_procedureSqlStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5061);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,746,_ctx) ) {
			case 1:
				{
				setState(5059);
				compoundStatement();
				}
				break;
			case 2:
				{
				setState(5060);
				sqlStatement();
				}
				break;
			}
			setState(5063);
			match(SEMI);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CaseAlternativeContext extends ParserRuleContext {
		public TerminalNode WHEN() { return getToken(MariaDBParser.WHEN, 0); }
		public TerminalNode THEN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCaseAlternative(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCaseAlternative(this);
		}
	}

	public final CaseAlternativeContext caseAlternative() throws RecognitionException {
		CaseAlternativeContext _localctx = new CaseAlternativeContext(_ctx, getState());
		enterRule(_localctx, 430, RULE_caseAlternative);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(5065);
			match(WHEN);
			setState(5068);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,747,_ctx) ) {
			case 1:
				{
				setState(5066);
				constant();
				}
				break;
			case 2:
				{
				setState(5067);
				expression(0);
				}
				break;
			}
			setState(5070);
			match(THEN);
			setState(5072); 
			_errHandler.sync(this);
			_alt = 1;
			do {
				switch (_alt) {
				case 1:
					{
					{
					setState(5071);
					procedureSqlStatement();
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(5074); 
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,748,_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;
	}

	public static class ElifAlternativeContext extends ParserRuleContext {
		public TerminalNode ELSEIF() { return getToken(MariaDBParser.ELSEIF, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode THEN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterElifAlternative(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitElifAlternative(this);
		}
	}

	public final ElifAlternativeContext elifAlternative() throws RecognitionException {
		ElifAlternativeContext _localctx = new ElifAlternativeContext(_ctx, getState());
		enterRule(_localctx, 432, RULE_elifAlternative);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(5076);
			match(ELSEIF);
			setState(5077);
			expression(0);
			setState(5078);
			match(THEN);
			setState(5080); 
			_errHandler.sync(this);
			_alt = 1;
			do {
				switch (_alt) {
				case 1:
					{
					{
					setState(5079);
					procedureSqlStatement();
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(5082); 
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,749,_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;
	}

	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);
		}
	}
	public static class AlterUserMysqlV80Context extends AlterUserContext {
		public Token tlsNone;
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode USER() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode REQUIRE() { return getToken(MariaDBParser.REQUIRE, 0); }
		public TerminalNode WITH() { return getToken(MariaDBParser.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(MariaDBParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode ATTRIBUTE() { return getToken(MariaDBParser.ATTRIBUTE, 0); }
		public List tlsOption() {
			return getRuleContexts(TlsOptionContext.class);
		}
		public TlsOptionContext tlsOption(int i) {
			return getRuleContext(TlsOptionContext.class,i);
		}
		public TerminalNode NONE() { return getToken(MariaDBParser.NONE, 0); }
		public List userResourceOption() {
			return getRuleContexts(UserResourceOptionContext.class);
		}
		public UserResourceOptionContext userResourceOption(int i) {
			return getRuleContext(UserResourceOptionContext.class,i);
		}
		public List AND() { return getTokens(MariaDBParser.AND); }
		public TerminalNode AND(int i) {
			return getToken(MariaDBParser.AND, i);
		}
		public AlterUserMysqlV80Context(AlterUserContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterUserMysqlV80(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterUserMysqlV80(this);
		}
	}
	public static class AlterUserMysqlV56Context extends AlterUserContext {
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode USER() { return getToken(MariaDBParser.USER, 0); }
		public List userSpecification() {
			return getRuleContexts(UserSpecificationContext.class);
		}
		public UserSpecificationContext userSpecification(int i) {
			return getRuleContext(UserSpecificationContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public AlterUserMysqlV56Context(AlterUserContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterAlterUserMysqlV56(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAlterUserMysqlV56(this);
		}
	}

	public final AlterUserContext alterUser() throws RecognitionException {
		AlterUserContext _localctx = new AlterUserContext(_ctx, getState());
		enterRule(_localctx, 434, RULE_alterUser);
		int _la;
		try {
			setState(5144);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,762,_ctx) ) {
			case 1:
				_localctx = new AlterUserMysqlV56Context(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5084);
				match(ALTER);
				setState(5085);
				match(USER);
				setState(5086);
				userSpecification();
				setState(5091);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5087);
					match(COMMA);
					setState(5088);
					userSpecification();
					}
					}
					setState(5093);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new AlterUserMysqlV80Context(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5094);
				match(ALTER);
				setState(5095);
				match(USER);
				setState(5097);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IF) {
					{
					setState(5096);
					ifExists();
					}
				}

				setState(5099);
				userAuthOption();
				setState(5104);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5100);
					match(COMMA);
					setState(5101);
					userAuthOption();
					}
					}
					setState(5106);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5121);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==REQUIRE) {
					{
					setState(5107);
					match(REQUIRE);
					setState(5119);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case NONE:
						{
						setState(5108);
						((AlterUserMysqlV80Context)_localctx).tlsNone = match(NONE);
						}
						break;
					case SSL:
					case CIPHER:
					case ISSUER:
					case SUBJECT:
					case X509:
						{
						setState(5109);
						tlsOption();
						setState(5116);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==AND || _la==SSL || _la==CIPHER || _la==ISSUER || _la==SUBJECT || _la==X509) {
							{
							{
							setState(5111);
							_errHandler.sync(this);
							_la = _input.LA(1);
							if (_la==AND) {
								{
								setState(5110);
								match(AND);
								}
							}

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

				setState(5129);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH) {
					{
					setState(5123);
					match(WITH);
					setState(5125); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(5124);
						userResourceOption();
						}
						}
						setState(5127); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( ((((_la - 499)) & ~0x3f) == 0 && ((1L << (_la - 499)) & ((1L << (MAX_CONNECTIONS_PER_HOUR - 499)) | (1L << (MAX_QUERIES_PER_HOUR - 499)) | (1L << (MAX_UPDATES_PER_HOUR - 499)) | (1L << (MAX_USER_CONNECTIONS - 499)))) != 0) );
					}
				}

				setState(5135);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==ACCOUNT || _la==FAILED_LOGIN_ATTEMPTS || _la==PASSWORD || _la==PASSWORD_LOCK_TIME) {
					{
					setState(5133);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case FAILED_LOGIN_ATTEMPTS:
					case PASSWORD:
					case PASSWORD_LOCK_TIME:
						{
						setState(5131);
						userPasswordOption();
						}
						break;
					case ACCOUNT:
						{
						setState(5132);
						userLockOption();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
					setState(5137);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5142);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case COMMENT:
					{
					setState(5138);
					match(COMMENT);
					setState(5139);
					match(STRING_LITERAL);
					}
					break;
				case ATTRIBUTE:
					{
					setState(5140);
					match(ATTRIBUTE);
					setState(5141);
					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 UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				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;
	}

	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);
		}
	}
	public static class CreateUserMysqlV56Context extends CreateUserContext {
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode USER() { return getToken(MariaDBParser.USER, 0); }
		public List userAuthOption() {
			return getRuleContexts(UserAuthOptionContext.class);
		}
		public UserAuthOptionContext userAuthOption(int i) {
			return getRuleContext(UserAuthOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public CreateUserMysqlV56Context(CreateUserContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateUserMysqlV56(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateUserMysqlV56(this);
		}
	}
	public static class CreateUserMysqlV80Context extends CreateUserContext {
		public Token tlsNone;
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode USER() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode REQUIRE() { return getToken(MariaDBParser.REQUIRE, 0); }
		public TerminalNode WITH() { return getToken(MariaDBParser.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(MariaDBParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode ATTRIBUTE() { return getToken(MariaDBParser.ATTRIBUTE, 0); }
		public List tlsOption() {
			return getRuleContexts(TlsOptionContext.class);
		}
		public TlsOptionContext tlsOption(int i) {
			return getRuleContext(TlsOptionContext.class,i);
		}
		public TerminalNode NONE() { return getToken(MariaDBParser.NONE, 0); }
		public List userResourceOption() {
			return getRuleContexts(UserResourceOptionContext.class);
		}
		public UserResourceOptionContext userResourceOption(int i) {
			return getRuleContext(UserResourceOptionContext.class,i);
		}
		public List AND() { return getTokens(MariaDBParser.AND); }
		public TerminalNode AND(int i) {
			return getToken(MariaDBParser.AND, i);
		}
		public CreateUserMysqlV80Context(CreateUserContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateUserMysqlV80(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateUserMysqlV80(this);
		}
	}

	public final CreateUserContext createUser() throws RecognitionException {
		CreateUserContext _localctx = new CreateUserContext(_ctx, getState());
		enterRule(_localctx, 436, RULE_createUser);
		int _la;
		try {
			setState(5206);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,775,_ctx) ) {
			case 1:
				_localctx = new CreateUserMysqlV56Context(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5146);
				match(CREATE);
				setState(5147);
				match(USER);
				setState(5148);
				userAuthOption();
				setState(5153);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5149);
					match(COMMA);
					setState(5150);
					userAuthOption();
					}
					}
					setState(5155);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new CreateUserMysqlV80Context(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5156);
				match(CREATE);
				setState(5157);
				match(USER);
				setState(5159);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IF) {
					{
					setState(5158);
					ifNotExists();
					}
				}

				setState(5161);
				userAuthOption();
				setState(5166);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5162);
					match(COMMA);
					setState(5163);
					userAuthOption();
					}
					}
					setState(5168);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5183);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==REQUIRE) {
					{
					setState(5169);
					match(REQUIRE);
					setState(5181);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case NONE:
						{
						setState(5170);
						((CreateUserMysqlV80Context)_localctx).tlsNone = match(NONE);
						}
						break;
					case SSL:
					case CIPHER:
					case ISSUER:
					case SUBJECT:
					case X509:
						{
						setState(5171);
						tlsOption();
						setState(5178);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==AND || _la==SSL || _la==CIPHER || _la==ISSUER || _la==SUBJECT || _la==X509) {
							{
							{
							setState(5173);
							_errHandler.sync(this);
							_la = _input.LA(1);
							if (_la==AND) {
								{
								setState(5172);
								match(AND);
								}
							}

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

				setState(5191);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH) {
					{
					setState(5185);
					match(WITH);
					setState(5187); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(5186);
						userResourceOption();
						}
						}
						setState(5189); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( ((((_la - 499)) & ~0x3f) == 0 && ((1L << (_la - 499)) & ((1L << (MAX_CONNECTIONS_PER_HOUR - 499)) | (1L << (MAX_QUERIES_PER_HOUR - 499)) | (1L << (MAX_UPDATES_PER_HOUR - 499)) | (1L << (MAX_USER_CONNECTIONS - 499)))) != 0) );
					}
				}

				setState(5197);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==ACCOUNT || _la==FAILED_LOGIN_ATTEMPTS || _la==PASSWORD || _la==PASSWORD_LOCK_TIME) {
					{
					setState(5195);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case FAILED_LOGIN_ATTEMPTS:
					case PASSWORD:
					case PASSWORD_LOCK_TIME:
						{
						setState(5193);
						userPasswordOption();
						}
						break;
					case ACCOUNT:
						{
						setState(5194);
						userLockOption();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
					setState(5199);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5204);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case COMMENT:
					{
					setState(5200);
					match(COMMENT);
					setState(5201);
					match(STRING_LITERAL);
					}
					break;
				case ATTRIBUTE:
					{
					setState(5202);
					match(ATTRIBUTE);
					setState(5203);
					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 UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				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;
	}

	public static class DropUserContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode USER() { return getToken(MariaDBParser.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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDropUser(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDropUser(this);
		}
	}

	public final DropUserContext dropUser() throws RecognitionException {
		DropUserContext _localctx = new DropUserContext(_ctx, getState());
		enterRule(_localctx, 438, RULE_dropUser);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5208);
			match(DROP);
			setState(5209);
			match(USER);
			setState(5211);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IF) {
				{
				setState(5210);
				ifExists();
				}
			}

			setState(5213);
			userName();
			setState(5218);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(5214);
				match(COMMA);
				setState(5215);
				userName();
				}
				}
				setState(5220);
				_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;
	}

	public static class GrantStatementContext extends ParserRuleContext {
		public Token privilegeObject;
		public Token tlsNone;
		public List GRANT() { return getTokens(MariaDBParser.GRANT); }
		public TerminalNode GRANT(int i) {
			return getToken(MariaDBParser.GRANT, i);
		}
		public List privelegeClause() {
			return getRuleContexts(PrivelegeClauseContext.class);
		}
		public PrivelegeClauseContext privelegeClause(int i) {
			return getRuleContext(PrivelegeClauseContext.class,i);
		}
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public PrivilegeLevelContext privilegeLevel() {
			return getRuleContext(PrivilegeLevelContext.class,0);
		}
		public TerminalNode TO() { return getToken(MariaDBParser.TO, 0); }
		public List userAuthOption() {
			return getRuleContexts(UserAuthOptionContext.class);
		}
		public UserAuthOptionContext userAuthOption(int i) {
			return getRuleContext(UserAuthOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode REQUIRE() { return getToken(MariaDBParser.REQUIRE, 0); }
		public List WITH() { return getTokens(MariaDBParser.WITH); }
		public TerminalNode WITH(int i) {
			return getToken(MariaDBParser.WITH, i);
		}
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public TerminalNode ROLE() { return getToken(MariaDBParser.ROLE, 0); }
		public RoleOptionContext roleOption() {
			return getRuleContext(RoleOptionContext.class,0);
		}
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TerminalNode FUNCTION() { return getToken(MariaDBParser.FUNCTION, 0); }
		public TerminalNode PROCEDURE() { return getToken(MariaDBParser.PROCEDURE, 0); }
		public List tlsOption() {
			return getRuleContexts(TlsOptionContext.class);
		}
		public TlsOptionContext tlsOption(int i) {
			return getRuleContext(TlsOptionContext.class,i);
		}
		public TerminalNode NONE() { return getToken(MariaDBParser.NONE, 0); }
		public List OPTION() { return getTokens(MariaDBParser.OPTION); }
		public TerminalNode OPTION(int i) {
			return getToken(MariaDBParser.OPTION, i);
		}
		public List userResourceOption() {
			return getRuleContexts(UserResourceOptionContext.class);
		}
		public UserResourceOptionContext userResourceOption(int i) {
			return getRuleContext(UserResourceOptionContext.class,i);
		}
		public List AND() { return getTokens(MariaDBParser.AND); }
		public TerminalNode AND(int i) {
			return getToken(MariaDBParser.AND, i);
		}
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode ADMIN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterGrantStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitGrantStatement(this);
		}
	}

	public final GrantStatementContext grantStatement() throws RecognitionException {
		GrantStatementContext _localctx = new GrantStatementContext(_ctx, getState());
		enterRule(_localctx, 440, RULE_grantStatement);
		int _la;
		try {
			int _alt;
			setState(5314);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,796,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(5221);
				match(GRANT);
				setState(5222);
				privelegeClause();
				setState(5227);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5223);
					match(COMMA);
					setState(5224);
					privelegeClause();
					}
					}
					setState(5229);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5230);
				match(ON);
				setState(5232);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,779,_ctx) ) {
				case 1:
					{
					setState(5231);
					((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(5234);
				privilegeLevel();
				setState(5235);
				match(TO);
				setState(5236);
				userAuthOption();
				setState(5241);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5237);
					match(COMMA);
					setState(5238);
					userAuthOption();
					}
					}
					setState(5243);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5258);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==REQUIRE) {
					{
					setState(5244);
					match(REQUIRE);
					setState(5256);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case NONE:
						{
						setState(5245);
						((GrantStatementContext)_localctx).tlsNone = match(NONE);
						}
						break;
					case SSL:
					case CIPHER:
					case ISSUER:
					case SUBJECT:
					case X509:
						{
						setState(5246);
						tlsOption();
						setState(5253);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==AND || _la==SSL || _la==CIPHER || _la==ISSUER || _la==SUBJECT || _la==X509) {
							{
							{
							setState(5248);
							_errHandler.sync(this);
							_la = _input.LA(1);
							if (_la==AND) {
								{
								setState(5247);
								match(AND);
								}
							}

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

				setState(5269);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH) {
					{
					setState(5260);
					match(WITH);
					setState(5266);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,786,_ctx);
					while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
						if ( _alt==1 ) {
							{
							setState(5264);
							_errHandler.sync(this);
							switch (_input.LA(1)) {
							case GRANT:
								{
								setState(5261);
								match(GRANT);
								setState(5262);
								match(OPTION);
								}
								break;
							case MAX_CONNECTIONS_PER_HOUR:
							case MAX_QUERIES_PER_HOUR:
							case MAX_UPDATES_PER_HOUR:
							case MAX_USER_CONNECTIONS:
								{
								setState(5263);
								userResourceOption();
								}
								break;
							default:
								throw new NoViableAltException(this);
							}
							} 
						}
						setState(5268);
						_errHandler.sync(this);
						_alt = getInterpreter().adaptivePredict(_input,786,_ctx);
					}
					}
				}

				setState(5277);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(5271);
					match(AS);
					setState(5272);
					userName();
					setState(5273);
					match(WITH);
					setState(5274);
					match(ROLE);
					setState(5275);
					roleOption();
					}
				}

				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(5279);
				match(GRANT);
				setState(5282);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,789,_ctx) ) {
				case 1:
					{
					setState(5280);
					userName();
					}
					break;
				case 2:
					{
					setState(5281);
					uid();
					}
					break;
				}
				setState(5291);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5284);
					match(COMMA);
					setState(5287);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,790,_ctx) ) {
					case 1:
						{
						setState(5285);
						userName();
						}
						break;
					case 2:
						{
						setState(5286);
						uid();
						}
						break;
					}
					}
					}
					setState(5293);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5294);
				match(TO);
				setState(5297);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,792,_ctx) ) {
				case 1:
					{
					setState(5295);
					userName();
					}
					break;
				case 2:
					{
					setState(5296);
					uid();
					}
					break;
				}
				setState(5306);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5299);
					match(COMMA);
					setState(5302);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,793,_ctx) ) {
					case 1:
						{
						setState(5300);
						userName();
						}
						break;
					case 2:
						{
						setState(5301);
						uid();
						}
						break;
					}
					}
					}
					setState(5308);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5312);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH) {
					{
					setState(5309);
					match(WITH);
					setState(5310);
					match(ADMIN);
					setState(5311);
					match(OPTION);
					}
				}

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

	public static class RoleOptionContext extends ParserRuleContext {
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode NONE() { return getToken(MariaDBParser.NONE, 0); }
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public TerminalNode EXCEPT() { return getToken(MariaDBParser.EXCEPT, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRoleOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRoleOption(this);
		}
	}

	public final RoleOptionContext roleOption() throws RecognitionException {
		RoleOptionContext _localctx = new RoleOptionContext(_ctx, getState());
		enterRule(_localctx, 442, RULE_roleOption);
		int _la;
		try {
			setState(5338);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,800,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(5316);
				match(DEFAULT);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(5317);
				match(NONE);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(5318);
				match(ALL);
				setState(5328);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EXCEPT) {
					{
					setState(5319);
					match(EXCEPT);
					setState(5320);
					userName();
					setState(5325);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(5321);
						match(COMMA);
						setState(5322);
						userName();
						}
						}
						setState(5327);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(5330);
				userName();
				setState(5335);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5331);
					match(COMMA);
					setState(5332);
					userName();
					}
					}
					setState(5337);
					_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;
	}

	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(MariaDBParser.GRANT); }
		public TerminalNode GRANT(int i) {
			return getToken(MariaDBParser.GRANT, i);
		}
		public TerminalNode PROXY() { return getToken(MariaDBParser.PROXY, 0); }
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public TerminalNode TO() { return getToken(MariaDBParser.TO, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public TerminalNode OPTION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterGrantProxy(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitGrantProxy(this);
		}
	}

	public final GrantProxyContext grantProxy() throws RecognitionException {
		GrantProxyContext _localctx = new GrantProxyContext(_ctx, getState());
		enterRule(_localctx, 444, RULE_grantProxy);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5340);
			match(GRANT);
			setState(5341);
			match(PROXY);
			setState(5342);
			match(ON);
			setState(5343);
			((GrantProxyContext)_localctx).fromFirst = userName();
			setState(5344);
			match(TO);
			setState(5345);
			((GrantProxyContext)_localctx).toFirst = userName();
			setState(5350);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(5346);
				match(COMMA);
				setState(5347);
				((GrantProxyContext)_localctx).userName = userName();
				((GrantProxyContext)_localctx).toOther.add(((GrantProxyContext)_localctx).userName);
				}
				}
				setState(5352);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(5356);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WITH) {
				{
				setState(5353);
				match(WITH);
				setState(5354);
				match(GRANT);
				setState(5355);
				match(OPTION);
				}
			}

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

	public static class RenameUserContext extends ParserRuleContext {
		public TerminalNode RENAME() { return getToken(MariaDBParser.RENAME, 0); }
		public TerminalNode USER() { return getToken(MariaDBParser.USER, 0); }
		public List renameUserClause() {
			return getRuleContexts(RenameUserClauseContext.class);
		}
		public RenameUserClauseContext renameUserClause(int i) {
			return getRuleContext(RenameUserClauseContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRenameUser(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRenameUser(this);
		}
	}

	public final RenameUserContext renameUser() throws RecognitionException {
		RenameUserContext _localctx = new RenameUserContext(_ctx, getState());
		enterRule(_localctx, 446, RULE_renameUser);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5358);
			match(RENAME);
			setState(5359);
			match(USER);
			setState(5360);
			renameUserClause();
			setState(5365);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(5361);
				match(COMMA);
				setState(5362);
				renameUserClause();
				}
				}
				setState(5367);
				_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;
	}

	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);
		}
	}
	public static class DetailRevokeContext extends RevokeStatementContext {
		public Token privilegeObject;
		public TerminalNode REVOKE() { return getToken(MariaDBParser.REVOKE, 0); }
		public List privelegeClause() {
			return getRuleContexts(PrivelegeClauseContext.class);
		}
		public PrivelegeClauseContext privelegeClause(int i) {
			return getRuleContext(PrivelegeClauseContext.class,i);
		}
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public PrivilegeLevelContext privilegeLevel() {
			return getRuleContext(PrivilegeLevelContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TerminalNode FUNCTION() { return getToken(MariaDBParser.FUNCTION, 0); }
		public TerminalNode PROCEDURE() { return getToken(MariaDBParser.PROCEDURE, 0); }
		public DetailRevokeContext(RevokeStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterDetailRevoke(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDetailRevoke(this);
		}
	}
	public static class RoleRevokeContext extends RevokeStatementContext {
		public TerminalNode REVOKE() { return getToken(MariaDBParser.REVOKE, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public RoleRevokeContext(RevokeStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterRoleRevoke(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRoleRevoke(this);
		}
	}
	public static class ShortRevokeContext extends RevokeStatementContext {
		public TerminalNode REVOKE() { return getToken(MariaDBParser.REVOKE, 0); }
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode GRANT() { return getToken(MariaDBParser.GRANT, 0); }
		public TerminalNode OPTION() { return getToken(MariaDBParser.OPTION, 0); }
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public TerminalNode PRIVILEGES() { return getToken(MariaDBParser.PRIVILEGES, 0); }
		public ShortRevokeContext(RevokeStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShortRevoke(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShortRevoke(this);
		}
	}

	public final RevokeStatementContext revokeStatement() throws RecognitionException {
		RevokeStatementContext _localctx = new RevokeStatementContext(_ctx, getState());
		enterRule(_localctx, 448, RULE_revokeStatement);
		int _la;
		try {
			setState(5432);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,813,_ctx) ) {
			case 1:
				_localctx = new DetailRevokeContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5368);
				match(REVOKE);
				setState(5369);
				privelegeClause();
				setState(5374);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5370);
					match(COMMA);
					setState(5371);
					privelegeClause();
					}
					}
					setState(5376);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5377);
				match(ON);
				setState(5379);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,805,_ctx) ) {
				case 1:
					{
					setState(5378);
					((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(5381);
				privilegeLevel();
				setState(5382);
				match(FROM);
				setState(5383);
				userName();
				setState(5388);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5384);
					match(COMMA);
					setState(5385);
					userName();
					}
					}
					setState(5390);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new ShortRevokeContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5391);
				match(REVOKE);
				setState(5392);
				match(ALL);
				setState(5394);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PRIVILEGES) {
					{
					setState(5393);
					match(PRIVILEGES);
					}
				}

				setState(5396);
				match(COMMA);
				setState(5397);
				match(GRANT);
				setState(5398);
				match(OPTION);
				setState(5399);
				match(FROM);
				setState(5400);
				userName();
				setState(5405);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5401);
					match(COMMA);
					setState(5402);
					userName();
					}
					}
					setState(5407);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 3:
				_localctx = new RoleRevokeContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5408);
				match(REVOKE);
				setState(5409);
				uid();
				setState(5414);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5410);
					match(COMMA);
					setState(5411);
					uid();
					}
					}
					setState(5416);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5417);
				match(FROM);
				setState(5420);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,810,_ctx) ) {
				case 1:
					{
					setState(5418);
					userName();
					}
					break;
				case 2:
					{
					setState(5419);
					uid();
					}
					break;
				}
				setState(5429);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5422);
					match(COMMA);
					setState(5425);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,811,_ctx) ) {
					case 1:
						{
						setState(5423);
						userName();
						}
						break;
					case 2:
						{
						setState(5424);
						uid();
						}
						break;
					}
					}
					}
					setState(5431);
					_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;
	}

	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(MariaDBParser.REVOKE, 0); }
		public TerminalNode PROXY() { return getToken(MariaDBParser.PROXY, 0); }
		public TerminalNode ON() { return getToken(MariaDBParser.ON, 0); }
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRevokeProxy(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRevokeProxy(this);
		}
	}

	public final RevokeProxyContext revokeProxy() throws RecognitionException {
		RevokeProxyContext _localctx = new RevokeProxyContext(_ctx, getState());
		enterRule(_localctx, 450, RULE_revokeProxy);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5434);
			match(REVOKE);
			setState(5435);
			match(PROXY);
			setState(5436);
			match(ON);
			setState(5437);
			((RevokeProxyContext)_localctx).onUser = userName();
			setState(5438);
			match(FROM);
			setState(5439);
			((RevokeProxyContext)_localctx).fromFirst = userName();
			setState(5444);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(5440);
				match(COMMA);
				setState(5441);
				((RevokeProxyContext)_localctx).userName = userName();
				((RevokeProxyContext)_localctx).fromOther.add(((RevokeProxyContext)_localctx).userName);
				}
				}
				setState(5446);
				_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;
	}

	public static class SetPasswordStatementContext extends ParserRuleContext {
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode PASSWORD() { return getToken(MariaDBParser.PASSWORD, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public PasswordFunctionClauseContext passwordFunctionClause() {
			return getRuleContext(PasswordFunctionClauseContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetPasswordStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetPasswordStatement(this);
		}
	}

	public final SetPasswordStatementContext setPasswordStatement() throws RecognitionException {
		SetPasswordStatementContext _localctx = new SetPasswordStatementContext(_ctx, getState());
		enterRule(_localctx, 452, RULE_setPasswordStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5447);
			match(SET);
			setState(5448);
			match(PASSWORD);
			setState(5451);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FOR) {
				{
				setState(5449);
				match(FOR);
				setState(5450);
				userName();
				}
			}

			setState(5453);
			match(EQUAL_SYMBOL);
			setState(5456);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case OLD_PASSWORD:
			case PASSWORD:
				{
				setState(5454);
				passwordFunctionClause();
				}
				break;
			case STRING_LITERAL:
				{
				setState(5455);
				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;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUserSpecification(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUserSpecification(this);
		}
	}

	public final UserSpecificationContext userSpecification() throws RecognitionException {
		UserSpecificationContext _localctx = new UserSpecificationContext(_ctx, getState());
		enterRule(_localctx, 454, RULE_userSpecification);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5458);
			userName();
			setState(5459);
			userPasswordOption();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSimpleAuthOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSimpleAuthOption(this);
		}
	}
	public static class ModuleAuthOptionContext extends UserAuthOptionContext {
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public TerminalNode IDENTIFIED() { return getToken(MariaDBParser.IDENTIFIED, 0); }
		public List authenticationRule() {
			return getRuleContexts(AuthenticationRuleContext.class);
		}
		public AuthenticationRuleContext authenticationRule(int i) {
			return getRuleContext(AuthenticationRuleContext.class,i);
		}
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public TerminalNode VIA() { return getToken(MariaDBParser.VIA, 0); }
		public List OR() { return getTokens(MariaDBParser.OR); }
		public TerminalNode OR(int i) {
			return getToken(MariaDBParser.OR, i);
		}
		public ModuleAuthOptionContext(UserAuthOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterModuleAuthOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitModuleAuthOption(this);
		}
	}
	public static class StringAuthOptionContext extends UserAuthOptionContext {
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public TerminalNode IDENTIFIED() { return getToken(MariaDBParser.IDENTIFIED, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode RETAIN() { return getToken(MariaDBParser.RETAIN, 0); }
		public TerminalNode CURRENT() { return getToken(MariaDBParser.CURRENT, 0); }
		public TerminalNode PASSWORD() { return getToken(MariaDBParser.PASSWORD, 0); }
		public StringAuthOptionContext(UserAuthOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterStringAuthOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStringAuthOption(this);
		}
	}
	public static class HashAuthOptionContext extends UserAuthOptionContext {
		public Token hashed;
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public TerminalNode IDENTIFIED() { return getToken(MariaDBParser.IDENTIFIED, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public TerminalNode PASSWORD() { return getToken(MariaDBParser.PASSWORD, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public HashAuthOptionContext(UserAuthOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterHashAuthOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHashAuthOption(this);
		}
	}

	public final UserAuthOptionContext userAuthOption() throws RecognitionException {
		UserAuthOptionContext _localctx = new UserAuthOptionContext(_ctx, getState());
		enterRule(_localctx, 456, RULE_userAuthOption);
		int _la;
		try {
			setState(5488);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,819,_ctx) ) {
			case 1:
				_localctx = new HashAuthOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5461);
				userName();
				setState(5462);
				match(IDENTIFIED);
				setState(5463);
				match(BY);
				setState(5464);
				match(PASSWORD);
				setState(5465);
				((HashAuthOptionContext)_localctx).hashed = match(STRING_LITERAL);
				}
				break;
			case 2:
				_localctx = new StringAuthOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5467);
				userName();
				setState(5468);
				match(IDENTIFIED);
				setState(5469);
				match(BY);
				setState(5470);
				match(STRING_LITERAL);
				setState(5474);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==RETAIN) {
					{
					setState(5471);
					match(RETAIN);
					setState(5472);
					match(CURRENT);
					setState(5473);
					match(PASSWORD);
					}
				}

				}
				break;
			case 3:
				_localctx = new ModuleAuthOptionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5476);
				userName();
				setState(5477);
				match(IDENTIFIED);
				setState(5478);
				_la = _input.LA(1);
				if ( !(_la==WITH || _la==VIA) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5479);
				authenticationRule();
				setState(5484);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==OR) {
					{
					{
					setState(5480);
					match(OR);
					setState(5481);
					authenticationRule();
					}
					}
					setState(5486);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 4:
				_localctx = new SimpleAuthOptionContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(5487);
				userName();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class PasswordModuleOptionContext extends AuthenticationRuleContext {
		public AuthPluginContext authPlugin() {
			return getRuleContext(AuthPluginContext.class,0);
		}
		public PasswordFunctionClauseContext passwordFunctionClause() {
			return getRuleContext(PasswordFunctionClauseContext.class,0);
		}
		public TerminalNode USING() { return getToken(MariaDBParser.USING, 0); }
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public PasswordModuleOptionContext(AuthenticationRuleContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterPasswordModuleOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPasswordModuleOption(this);
		}
	}
	public static class ModuleContext extends AuthenticationRuleContext {
		public AuthPluginContext authPlugin() {
			return getRuleContext(AuthPluginContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public TerminalNode USING() { return getToken(MariaDBParser.USING, 0); }
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public ModuleContext(AuthenticationRuleContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterModule(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitModule(this);
		}
	}

	public final AuthenticationRuleContext authenticationRule() throws RecognitionException {
		AuthenticationRuleContext _localctx = new AuthenticationRuleContext(_ctx, getState());
		enterRule(_localctx, 458, RULE_authenticationRule);
		int _la;
		try {
			setState(5499);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,821,_ctx) ) {
			case 1:
				_localctx = new ModuleContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5490);
				authPlugin();
				setState(5493);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,820,_ctx) ) {
				case 1:
					{
					setState(5491);
					_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(5492);
					match(STRING_LITERAL);
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new PasswordModuleOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5495);
				authPlugin();
				setState(5496);
				_la = _input.LA(1);
				if ( !(_la==AS || _la==USING) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5497);
				passwordFunctionClause();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class TlsOptionContext extends ParserRuleContext {
		public TerminalNode SSL() { return getToken(MariaDBParser.SSL, 0); }
		public TerminalNode X509() { return getToken(MariaDBParser.X509, 0); }
		public TerminalNode CIPHER() { return getToken(MariaDBParser.CIPHER, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode ISSUER() { return getToken(MariaDBParser.ISSUER, 0); }
		public TerminalNode SUBJECT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTlsOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTlsOption(this);
		}
	}

	public final TlsOptionContext tlsOption() throws RecognitionException {
		TlsOptionContext _localctx = new TlsOptionContext(_ctx, getState());
		enterRule(_localctx, 460, RULE_tlsOption);
		try {
			setState(5509);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SSL:
				enterOuterAlt(_localctx, 1);
				{
				setState(5501);
				match(SSL);
				}
				break;
			case X509:
				enterOuterAlt(_localctx, 2);
				{
				setState(5502);
				match(X509);
				}
				break;
			case CIPHER:
				enterOuterAlt(_localctx, 3);
				{
				setState(5503);
				match(CIPHER);
				setState(5504);
				match(STRING_LITERAL);
				}
				break;
			case ISSUER:
				enterOuterAlt(_localctx, 4);
				{
				setState(5505);
				match(ISSUER);
				setState(5506);
				match(STRING_LITERAL);
				}
				break;
			case SUBJECT:
				enterOuterAlt(_localctx, 5);
				{
				setState(5507);
				match(SUBJECT);
				setState(5508);
				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;
	}

	public static class UserResourceOptionContext extends ParserRuleContext {
		public TerminalNode MAX_QUERIES_PER_HOUR() { return getToken(MariaDBParser.MAX_QUERIES_PER_HOUR, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode MAX_UPDATES_PER_HOUR() { return getToken(MariaDBParser.MAX_UPDATES_PER_HOUR, 0); }
		public TerminalNode MAX_CONNECTIONS_PER_HOUR() { return getToken(MariaDBParser.MAX_CONNECTIONS_PER_HOUR, 0); }
		public TerminalNode MAX_USER_CONNECTIONS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUserResourceOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUserResourceOption(this);
		}
	}

	public final UserResourceOptionContext userResourceOption() throws RecognitionException {
		UserResourceOptionContext _localctx = new UserResourceOptionContext(_ctx, getState());
		enterRule(_localctx, 462, RULE_userResourceOption);
		try {
			setState(5519);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case MAX_QUERIES_PER_HOUR:
				enterOuterAlt(_localctx, 1);
				{
				setState(5511);
				match(MAX_QUERIES_PER_HOUR);
				setState(5512);
				decimalLiteral();
				}
				break;
			case MAX_UPDATES_PER_HOUR:
				enterOuterAlt(_localctx, 2);
				{
				setState(5513);
				match(MAX_UPDATES_PER_HOUR);
				setState(5514);
				decimalLiteral();
				}
				break;
			case MAX_CONNECTIONS_PER_HOUR:
				enterOuterAlt(_localctx, 3);
				{
				setState(5515);
				match(MAX_CONNECTIONS_PER_HOUR);
				setState(5516);
				decimalLiteral();
				}
				break;
			case MAX_USER_CONNECTIONS:
				enterOuterAlt(_localctx, 4);
				{
				setState(5517);
				match(MAX_USER_CONNECTIONS);
				setState(5518);
				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;
	}

	public static class UserPasswordOptionContext extends ParserRuleContext {
		public Token expireType;
		public TerminalNode PASSWORD() { return getToken(MariaDBParser.PASSWORD, 0); }
		public TerminalNode EXPIRE() { return getToken(MariaDBParser.EXPIRE, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode DAY() { return getToken(MariaDBParser.DAY, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode NEVER() { return getToken(MariaDBParser.NEVER, 0); }
		public TerminalNode INTERVAL() { return getToken(MariaDBParser.INTERVAL, 0); }
		public TerminalNode HISTORY() { return getToken(MariaDBParser.HISTORY, 0); }
		public TerminalNode REUSE() { return getToken(MariaDBParser.REUSE, 0); }
		public TerminalNode REQUIRE() { return getToken(MariaDBParser.REQUIRE, 0); }
		public TerminalNode CURRENT() { return getToken(MariaDBParser.CURRENT, 0); }
		public TerminalNode OPTIONAL() { return getToken(MariaDBParser.OPTIONAL, 0); }
		public TerminalNode FAILED_LOGIN_ATTEMPTS() { return getToken(MariaDBParser.FAILED_LOGIN_ATTEMPTS, 0); }
		public TerminalNode PASSWORD_LOCK_TIME() { return getToken(MariaDBParser.PASSWORD_LOCK_TIME, 0); }
		public TerminalNode UNBOUNDED() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUserPasswordOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUserPasswordOption(this);
		}
	}

	public final UserPasswordOptionContext userPasswordOption() throws RecognitionException {
		UserPasswordOptionContext _localctx = new UserPasswordOptionContext(_ctx, getState());
		enterRule(_localctx, 464, RULE_userPasswordOption);
		int _la;
		try {
			setState(5559);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,829,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(5521);
				match(PASSWORD);
				setState(5522);
				match(EXPIRE);
				setState(5529);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case DEFAULT:
					{
					setState(5523);
					((UserPasswordOptionContext)_localctx).expireType = match(DEFAULT);
					}
					break;
				case NEVER:
					{
					setState(5524);
					((UserPasswordOptionContext)_localctx).expireType = match(NEVER);
					}
					break;
				case INTERVAL:
					{
					setState(5525);
					((UserPasswordOptionContext)_localctx).expireType = match(INTERVAL);
					setState(5526);
					decimalLiteral();
					setState(5527);
					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 UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				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(5531);
				match(PASSWORD);
				setState(5532);
				match(HISTORY);
				setState(5535);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case DEFAULT:
					{
					setState(5533);
					match(DEFAULT);
					}
					break;
				case ZERO_DECIMAL:
				case ONE_DECIMAL:
				case TWO_DECIMAL:
				case DECIMAL_LITERAL:
				case REAL_LITERAL:
					{
					setState(5534);
					decimalLiteral();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(5537);
				match(PASSWORD);
				setState(5538);
				match(REUSE);
				setState(5539);
				match(INTERVAL);
				setState(5544);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case DEFAULT:
					{
					setState(5540);
					match(DEFAULT);
					}
					break;
				case ZERO_DECIMAL:
				case ONE_DECIMAL:
				case TWO_DECIMAL:
				case DECIMAL_LITERAL:
				case REAL_LITERAL:
					{
					setState(5541);
					decimalLiteral();
					setState(5542);
					match(DAY);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(5546);
				match(PASSWORD);
				setState(5547);
				match(REQUIRE);
				setState(5548);
				match(CURRENT);
				setState(5550);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT || _la==OPTIONAL) {
					{
					setState(5549);
					_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(5552);
				match(FAILED_LOGIN_ATTEMPTS);
				setState(5553);
				decimalLiteral();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(5554);
				match(PASSWORD_LOCK_TIME);
				setState(5557);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ZERO_DECIMAL:
				case ONE_DECIMAL:
				case TWO_DECIMAL:
				case DECIMAL_LITERAL:
				case REAL_LITERAL:
					{
					setState(5555);
					decimalLiteral();
					}
					break;
				case UNBOUNDED:
					{
					setState(5556);
					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;
	}

	public static class UserLockOptionContext extends ParserRuleContext {
		public Token lockType;
		public TerminalNode ACCOUNT() { return getToken(MariaDBParser.ACCOUNT, 0); }
		public TerminalNode LOCK() { return getToken(MariaDBParser.LOCK, 0); }
		public TerminalNode UNLOCK() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUserLockOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUserLockOption(this);
		}
	}

	public final UserLockOptionContext userLockOption() throws RecognitionException {
		UserLockOptionContext _localctx = new UserLockOptionContext(_ctx, getState());
		enterRule(_localctx, 466, RULE_userLockOption);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5561);
			match(ACCOUNT);
			setState(5562);
			((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;
	}

	public static class PrivelegeClauseContext extends ParserRuleContext {
		public PrivilegeContext privilege() {
			return getRuleContext(PrivilegeContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPrivelegeClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPrivelegeClause(this);
		}
	}

	public final PrivelegeClauseContext privelegeClause() throws RecognitionException {
		PrivelegeClauseContext _localctx = new PrivelegeClauseContext(_ctx, getState());
		enterRule(_localctx, 468, RULE_privelegeClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5564);
			privilege();
			setState(5569);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LR_BRACKET) {
				{
				setState(5565);
				match(LR_BRACKET);
				setState(5566);
				uidList();
				setState(5567);
				match(RR_BRACKET);
				}
			}

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

	public static class PrivilegeContext extends ParserRuleContext {
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public TerminalNode PRIVILEGES() { return getToken(MariaDBParser.PRIVILEGES, 0); }
		public TerminalNode ALTER() { return getToken(MariaDBParser.ALTER, 0); }
		public TerminalNode ROUTINE() { return getToken(MariaDBParser.ROUTINE, 0); }
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode TEMPORARY() { return getToken(MariaDBParser.TEMPORARY, 0); }
		public TerminalNode TABLES() { return getToken(MariaDBParser.TABLES, 0); }
		public TerminalNode VIEW() { return getToken(MariaDBParser.VIEW, 0); }
		public TerminalNode USER() { return getToken(MariaDBParser.USER, 0); }
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public TerminalNode ROLE() { return getToken(MariaDBParser.ROLE, 0); }
		public TerminalNode DELETE() { return getToken(MariaDBParser.DELETE, 0); }
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode EVENT() { return getToken(MariaDBParser.EVENT, 0); }
		public TerminalNode EXECUTE() { return getToken(MariaDBParser.EXECUTE, 0); }
		public TerminalNode FILE() { return getToken(MariaDBParser.FILE, 0); }
		public TerminalNode GRANT() { return getToken(MariaDBParser.GRANT, 0); }
		public TerminalNode OPTION() { return getToken(MariaDBParser.OPTION, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode INSERT() { return getToken(MariaDBParser.INSERT, 0); }
		public TerminalNode LOCK() { return getToken(MariaDBParser.LOCK, 0); }
		public TerminalNode PROCESS() { return getToken(MariaDBParser.PROCESS, 0); }
		public TerminalNode PROXY() { return getToken(MariaDBParser.PROXY, 0); }
		public TerminalNode REFERENCES() { return getToken(MariaDBParser.REFERENCES, 0); }
		public TerminalNode RELOAD() { return getToken(MariaDBParser.RELOAD, 0); }
		public TerminalNode REPLICATION() { return getToken(MariaDBParser.REPLICATION, 0); }
		public TerminalNode CLIENT() { return getToken(MariaDBParser.CLIENT, 0); }
		public TerminalNode SLAVE() { return getToken(MariaDBParser.SLAVE, 0); }
		public TerminalNode REPLICA() { return getToken(MariaDBParser.REPLICA, 0); }
		public TerminalNode MASTER() { return getToken(MariaDBParser.MASTER, 0); }
		public TerminalNode ADMIN() { return getToken(MariaDBParser.ADMIN, 0); }
		public TerminalNode SELECT() { return getToken(MariaDBParser.SELECT, 0); }
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode DATABASES() { return getToken(MariaDBParser.DATABASES, 0); }
		public TerminalNode SCHEMAS() { return getToken(MariaDBParser.SCHEMAS, 0); }
		public TerminalNode SHUTDOWN() { return getToken(MariaDBParser.SHUTDOWN, 0); }
		public TerminalNode SUPER() { return getToken(MariaDBParser.SUPER, 0); }
		public TerminalNode TRIGGER() { return getToken(MariaDBParser.TRIGGER, 0); }
		public TerminalNode UPDATE() { return getToken(MariaDBParser.UPDATE, 0); }
		public TerminalNode USAGE() { return getToken(MariaDBParser.USAGE, 0); }
		public TerminalNode APPLICATION_PASSWORD_ADMIN() { return getToken(MariaDBParser.APPLICATION_PASSWORD_ADMIN, 0); }
		public TerminalNode AUDIT_ADMIN() { return getToken(MariaDBParser.AUDIT_ADMIN, 0); }
		public TerminalNode BACKUP_ADMIN() { return getToken(MariaDBParser.BACKUP_ADMIN, 0); }
		public TerminalNode BINLOG_ADMIN() { return getToken(MariaDBParser.BINLOG_ADMIN, 0); }
		public TerminalNode BINLOG_ENCRYPTION_ADMIN() { return getToken(MariaDBParser.BINLOG_ENCRYPTION_ADMIN, 0); }
		public TerminalNode CLONE_ADMIN() { return getToken(MariaDBParser.CLONE_ADMIN, 0); }
		public TerminalNode CONNECTION_ADMIN() { return getToken(MariaDBParser.CONNECTION_ADMIN, 0); }
		public TerminalNode ENCRYPTION_KEY_ADMIN() { return getToken(MariaDBParser.ENCRYPTION_KEY_ADMIN, 0); }
		public TerminalNode FIREWALL_ADMIN() { return getToken(MariaDBParser.FIREWALL_ADMIN, 0); }
		public TerminalNode FIREWALL_USER() { return getToken(MariaDBParser.FIREWALL_USER, 0); }
		public TerminalNode FLUSH_OPTIMIZER_COSTS() { return getToken(MariaDBParser.FLUSH_OPTIMIZER_COSTS, 0); }
		public TerminalNode FLUSH_STATUS() { return getToken(MariaDBParser.FLUSH_STATUS, 0); }
		public TerminalNode FLUSH_TABLES() { return getToken(MariaDBParser.FLUSH_TABLES, 0); }
		public TerminalNode FLUSH_USER_RESOURCES() { return getToken(MariaDBParser.FLUSH_USER_RESOURCES, 0); }
		public TerminalNode GROUP_REPLICATION_ADMIN() { return getToken(MariaDBParser.GROUP_REPLICATION_ADMIN, 0); }
		public TerminalNode INNODB_REDO_LOG_ARCHIVE() { return getToken(MariaDBParser.INNODB_REDO_LOG_ARCHIVE, 0); }
		public TerminalNode INNODB_REDO_LOG_ENABLE() { return getToken(MariaDBParser.INNODB_REDO_LOG_ENABLE, 0); }
		public TerminalNode NDB_STORED_USER() { return getToken(MariaDBParser.NDB_STORED_USER, 0); }
		public TerminalNode PASSWORDLESS_USER_ADMIN() { return getToken(MariaDBParser.PASSWORDLESS_USER_ADMIN, 0); }
		public TerminalNode PERSIST_RO_VARIABLES_ADMIN() { return getToken(MariaDBParser.PERSIST_RO_VARIABLES_ADMIN, 0); }
		public TerminalNode REPLICATION_APPLIER() { return getToken(MariaDBParser.REPLICATION_APPLIER, 0); }
		public TerminalNode REPLICATION_SLAVE_ADMIN() { return getToken(MariaDBParser.REPLICATION_SLAVE_ADMIN, 0); }
		public TerminalNode RESOURCE_GROUP_ADMIN() { return getToken(MariaDBParser.RESOURCE_GROUP_ADMIN, 0); }
		public TerminalNode RESOURCE_GROUP_USER() { return getToken(MariaDBParser.RESOURCE_GROUP_USER, 0); }
		public TerminalNode ROLE_ADMIN() { return getToken(MariaDBParser.ROLE_ADMIN, 0); }
		public TerminalNode SERVICE_CONNECTION_ADMIN() { return getToken(MariaDBParser.SERVICE_CONNECTION_ADMIN, 0); }
		public TerminalNode SESSION_VARIABLES_ADMIN() { return getToken(MariaDBParser.SESSION_VARIABLES_ADMIN, 0); }
		public TerminalNode SET_USER_ID() { return getToken(MariaDBParser.SET_USER_ID, 0); }
		public TerminalNode SHOW_ROUTINE() { return getToken(MariaDBParser.SHOW_ROUTINE, 0); }
		public TerminalNode SYSTEM_USER() { return getToken(MariaDBParser.SYSTEM_USER, 0); }
		public TerminalNode SYSTEM_VARIABLES_ADMIN() { return getToken(MariaDBParser.SYSTEM_VARIABLES_ADMIN, 0); }
		public TerminalNode TABLE_ENCRYPTION_ADMIN() { return getToken(MariaDBParser.TABLE_ENCRYPTION_ADMIN, 0); }
		public TerminalNode VERSION_TOKEN_ADMIN() { return getToken(MariaDBParser.VERSION_TOKEN_ADMIN, 0); }
		public TerminalNode XA_RECOVER_ADMIN() { return getToken(MariaDBParser.XA_RECOVER_ADMIN, 0); }
		public TerminalNode BINLOG_MONITOR() { return getToken(MariaDBParser.BINLOG_MONITOR, 0); }
		public TerminalNode BINLOG_REPLAY() { return getToken(MariaDBParser.BINLOG_REPLAY, 0); }
		public TerminalNode FEDERATED_ADMIN() { return getToken(MariaDBParser.FEDERATED_ADMIN, 0); }
		public TerminalNode READ_ONLY_ADMIN() { return getToken(MariaDBParser.READ_ONLY_ADMIN, 0); }
		public TerminalNode REPLICATION_MASTER_ADMIN() { return getToken(MariaDBParser.REPLICATION_MASTER_ADMIN, 0); }
		public TerminalNode BINLOG() { return getToken(MariaDBParser.BINLOG, 0); }
		public TerminalNode MONITOR() { return getToken(MariaDBParser.MONITOR, 0); }
		public TerminalNode REPLAY() { return getToken(MariaDBParser.REPLAY, 0); }
		public TerminalNode FEDERATED() { return getToken(MariaDBParser.FEDERATED, 0); }
		public TerminalNode READ() { return getToken(MariaDBParser.READ, 0); }
		public TerminalNode ONLY() { return getToken(MariaDBParser.ONLY, 0); }
		public TerminalNode READ_ONLY() { return getToken(MariaDBParser.READ_ONLY, 0); }
		public TerminalNode CONNECTION() { return getToken(MariaDBParser.CONNECTION, 0); }
		public TerminalNode HISTORY() { return getToken(MariaDBParser.HISTORY, 0); }
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode LOAD() { return getToken(MariaDBParser.LOAD, 0); }
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public TerminalNode S3() { return getToken(MariaDBParser.S3, 0); }
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public TerminalNode INVOKE() { return getToken(MariaDBParser.INVOKE, 0); }
		public TerminalNode LAMBDA() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPrivilege(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPrivilege(this);
		}
	}

	public final PrivilegeContext privilege() throws RecognitionException {
		PrivilegeContext _localctx = new PrivilegeContext(_ctx, getState());
		enterRule(_localctx, 470, RULE_privilege);
		int _la;
		try {
			setState(5691);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,837,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(5571);
				match(ALL);
				setState(5573);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PRIVILEGES) {
					{
					setState(5572);
					match(PRIVILEGES);
					}
				}

				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(5575);
				match(ALTER);
				setState(5577);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ROUTINE) {
					{
					setState(5576);
					match(ROUTINE);
					}
				}

				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(5579);
				match(CREATE);
				setState(5587);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case TEMPORARY:
					{
					setState(5580);
					match(TEMPORARY);
					setState(5581);
					match(TABLES);
					}
					break;
				case ROUTINE:
					{
					setState(5582);
					match(ROUTINE);
					}
					break;
				case VIEW:
					{
					setState(5583);
					match(VIEW);
					}
					break;
				case USER:
					{
					setState(5584);
					match(USER);
					}
					break;
				case TABLESPACE:
					{
					setState(5585);
					match(TABLESPACE);
					}
					break;
				case ROLE:
					{
					setState(5586);
					match(ROLE);
					}
					break;
				case ON:
				case LR_BRACKET:
				case COMMA:
					break;
				default:
					break;
				}
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(5589);
				match(DELETE);
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(5590);
				match(DROP);
				setState(5592);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ROLE) {
					{
					setState(5591);
					match(ROLE);
					}
				}

				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(5594);
				match(EVENT);
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(5595);
				match(EXECUTE);
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(5596);
				match(FILE);
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(5597);
				match(GRANT);
				setState(5598);
				match(OPTION);
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(5599);
				match(INDEX);
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(5600);
				match(INSERT);
				}
				break;
			case 12:
				enterOuterAlt(_localctx, 12);
				{
				setState(5601);
				match(LOCK);
				setState(5602);
				match(TABLES);
				}
				break;
			case 13:
				enterOuterAlt(_localctx, 13);
				{
				setState(5603);
				match(PROCESS);
				}
				break;
			case 14:
				enterOuterAlt(_localctx, 14);
				{
				setState(5604);
				match(PROXY);
				}
				break;
			case 15:
				enterOuterAlt(_localctx, 15);
				{
				setState(5605);
				match(REFERENCES);
				}
				break;
			case 16:
				enterOuterAlt(_localctx, 16);
				{
				setState(5606);
				match(RELOAD);
				}
				break;
			case 17:
				enterOuterAlt(_localctx, 17);
				{
				setState(5607);
				match(REPLICATION);
				setState(5608);
				_la = _input.LA(1);
				if ( !(_la==CLIENT || _la==MASTER || _la==SLAVE || _la==REPLICA) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5610);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ADMIN) {
					{
					setState(5609);
					match(ADMIN);
					}
				}

				}
				break;
			case 18:
				enterOuterAlt(_localctx, 18);
				{
				setState(5612);
				match(SELECT);
				}
				break;
			case 19:
				enterOuterAlt(_localctx, 19);
				{
				setState(5613);
				match(SHOW);
				setState(5614);
				_la = _input.LA(1);
				if ( !(_la==DATABASES || _la==SCHEMAS || _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(5615);
				match(SHUTDOWN);
				}
				break;
			case 21:
				enterOuterAlt(_localctx, 21);
				{
				setState(5616);
				match(SUPER);
				}
				break;
			case 22:
				enterOuterAlt(_localctx, 22);
				{
				setState(5617);
				match(TRIGGER);
				}
				break;
			case 23:
				enterOuterAlt(_localctx, 23);
				{
				setState(5618);
				match(UPDATE);
				}
				break;
			case 24:
				enterOuterAlt(_localctx, 24);
				{
				setState(5619);
				match(USAGE);
				}
				break;
			case 25:
				enterOuterAlt(_localctx, 25);
				{
				setState(5620);
				match(APPLICATION_PASSWORD_ADMIN);
				}
				break;
			case 26:
				enterOuterAlt(_localctx, 26);
				{
				setState(5621);
				match(AUDIT_ADMIN);
				}
				break;
			case 27:
				enterOuterAlt(_localctx, 27);
				{
				setState(5622);
				match(BACKUP_ADMIN);
				}
				break;
			case 28:
				enterOuterAlt(_localctx, 28);
				{
				setState(5623);
				match(BINLOG_ADMIN);
				}
				break;
			case 29:
				enterOuterAlt(_localctx, 29);
				{
				setState(5624);
				match(BINLOG_ENCRYPTION_ADMIN);
				}
				break;
			case 30:
				enterOuterAlt(_localctx, 30);
				{
				setState(5625);
				match(CLONE_ADMIN);
				}
				break;
			case 31:
				enterOuterAlt(_localctx, 31);
				{
				setState(5626);
				match(CONNECTION_ADMIN);
				}
				break;
			case 32:
				enterOuterAlt(_localctx, 32);
				{
				setState(5627);
				match(ENCRYPTION_KEY_ADMIN);
				}
				break;
			case 33:
				enterOuterAlt(_localctx, 33);
				{
				setState(5628);
				match(FIREWALL_ADMIN);
				}
				break;
			case 34:
				enterOuterAlt(_localctx, 34);
				{
				setState(5629);
				match(FIREWALL_USER);
				}
				break;
			case 35:
				enterOuterAlt(_localctx, 35);
				{
				setState(5630);
				match(FLUSH_OPTIMIZER_COSTS);
				}
				break;
			case 36:
				enterOuterAlt(_localctx, 36);
				{
				setState(5631);
				match(FLUSH_STATUS);
				}
				break;
			case 37:
				enterOuterAlt(_localctx, 37);
				{
				setState(5632);
				match(FLUSH_TABLES);
				}
				break;
			case 38:
				enterOuterAlt(_localctx, 38);
				{
				setState(5633);
				match(FLUSH_USER_RESOURCES);
				}
				break;
			case 39:
				enterOuterAlt(_localctx, 39);
				{
				setState(5634);
				match(GROUP_REPLICATION_ADMIN);
				}
				break;
			case 40:
				enterOuterAlt(_localctx, 40);
				{
				setState(5635);
				match(INNODB_REDO_LOG_ARCHIVE);
				}
				break;
			case 41:
				enterOuterAlt(_localctx, 41);
				{
				setState(5636);
				match(INNODB_REDO_LOG_ENABLE);
				}
				break;
			case 42:
				enterOuterAlt(_localctx, 42);
				{
				setState(5637);
				match(NDB_STORED_USER);
				}
				break;
			case 43:
				enterOuterAlt(_localctx, 43);
				{
				setState(5638);
				match(PASSWORDLESS_USER_ADMIN);
				}
				break;
			case 44:
				enterOuterAlt(_localctx, 44);
				{
				setState(5639);
				match(PERSIST_RO_VARIABLES_ADMIN);
				}
				break;
			case 45:
				enterOuterAlt(_localctx, 45);
				{
				setState(5640);
				match(REPLICATION_APPLIER);
				}
				break;
			case 46:
				enterOuterAlt(_localctx, 46);
				{
				setState(5641);
				match(REPLICATION_SLAVE_ADMIN);
				}
				break;
			case 47:
				enterOuterAlt(_localctx, 47);
				{
				setState(5642);
				match(RESOURCE_GROUP_ADMIN);
				}
				break;
			case 48:
				enterOuterAlt(_localctx, 48);
				{
				setState(5643);
				match(RESOURCE_GROUP_USER);
				}
				break;
			case 49:
				enterOuterAlt(_localctx, 49);
				{
				setState(5644);
				match(ROLE_ADMIN);
				}
				break;
			case 50:
				enterOuterAlt(_localctx, 50);
				{
				setState(5645);
				match(SERVICE_CONNECTION_ADMIN);
				}
				break;
			case 51:
				enterOuterAlt(_localctx, 51);
				{
				setState(5646);
				match(SESSION_VARIABLES_ADMIN);
				}
				break;
			case 52:
				enterOuterAlt(_localctx, 52);
				{
				setState(5647);
				match(SET_USER_ID);
				}
				break;
			case 53:
				enterOuterAlt(_localctx, 53);
				{
				setState(5648);
				match(SHOW_ROUTINE);
				}
				break;
			case 54:
				enterOuterAlt(_localctx, 54);
				{
				setState(5649);
				match(SYSTEM_USER);
				}
				break;
			case 55:
				enterOuterAlt(_localctx, 55);
				{
				setState(5650);
				match(SYSTEM_VARIABLES_ADMIN);
				}
				break;
			case 56:
				enterOuterAlt(_localctx, 56);
				{
				setState(5651);
				match(TABLE_ENCRYPTION_ADMIN);
				}
				break;
			case 57:
				enterOuterAlt(_localctx, 57);
				{
				setState(5652);
				match(VERSION_TOKEN_ADMIN);
				}
				break;
			case 58:
				enterOuterAlt(_localctx, 58);
				{
				setState(5653);
				match(XA_RECOVER_ADMIN);
				}
				break;
			case 59:
				enterOuterAlt(_localctx, 59);
				{
				setState(5654);
				match(BINLOG_MONITOR);
				}
				break;
			case 60:
				enterOuterAlt(_localctx, 60);
				{
				setState(5655);
				match(BINLOG_REPLAY);
				}
				break;
			case 61:
				enterOuterAlt(_localctx, 61);
				{
				setState(5656);
				match(FEDERATED_ADMIN);
				}
				break;
			case 62:
				enterOuterAlt(_localctx, 62);
				{
				setState(5657);
				match(READ_ONLY_ADMIN);
				}
				break;
			case 63:
				enterOuterAlt(_localctx, 63);
				{
				setState(5658);
				match(REPLICATION_MASTER_ADMIN);
				}
				break;
			case 64:
				enterOuterAlt(_localctx, 64);
				{
				setState(5659);
				match(BINLOG);
				setState(5660);
				_la = _input.LA(1);
				if ( !(_la==ADMIN || _la==MONITOR || _la==REPLAY) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 65:
				enterOuterAlt(_localctx, 65);
				{
				setState(5661);
				match(FEDERATED);
				setState(5662);
				match(ADMIN);
				}
				break;
			case 66:
				enterOuterAlt(_localctx, 66);
				{
				setState(5666);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case READ:
					{
					setState(5663);
					match(READ);
					setState(5664);
					match(ONLY);
					}
					break;
				case READ_ONLY:
					{
					setState(5665);
					match(READ_ONLY);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(5668);
				match(ADMIN);
				}
				break;
			case 67:
				enterOuterAlt(_localctx, 67);
				{
				setState(5669);
				match(ADMIN);
				setState(5670);
				match(OPTION);
				}
				break;
			case 68:
				enterOuterAlt(_localctx, 68);
				{
				setState(5671);
				match(CONNECTION);
				setState(5672);
				match(ADMIN);
				}
				break;
			case 69:
				enterOuterAlt(_localctx, 69);
				{
				setState(5673);
				match(DELETE);
				setState(5674);
				match(HISTORY);
				}
				break;
			case 70:
				enterOuterAlt(_localctx, 70);
				{
				setState(5675);
				match(REPLICA);
				setState(5676);
				match(MONITOR);
				}
				break;
			case 71:
				enterOuterAlt(_localctx, 71);
				{
				setState(5677);
				match(GRANT);
				setState(5678);
				match(OPTION);
				}
				break;
			case 72:
				enterOuterAlt(_localctx, 72);
				{
				setState(5679);
				match(SET);
				setState(5680);
				match(USER);
				}
				break;
			case 73:
				enterOuterAlt(_localctx, 73);
				{
				setState(5681);
				match(SLAVE);
				setState(5682);
				match(MONITOR);
				}
				break;
			case 74:
				enterOuterAlt(_localctx, 74);
				{
				setState(5683);
				match(LOAD);
				setState(5684);
				match(FROM);
				setState(5685);
				match(S3);
				}
				break;
			case 75:
				enterOuterAlt(_localctx, 75);
				{
				setState(5686);
				match(SELECT);
				setState(5687);
				match(INTO);
				setState(5688);
				match(S3);
				}
				break;
			case 76:
				enterOuterAlt(_localctx, 76);
				{
				setState(5689);
				match(INVOKE);
				setState(5690);
				match(LAMBDA);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class DefiniteSchemaPrivLevelContext extends PrivilegeLevelContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DOT() { return getToken(MariaDBParser.DOT, 0); }
		public TerminalNode STAR() { return getToken(MariaDBParser.STAR, 0); }
		public DefiniteSchemaPrivLevelContext(PrivilegeLevelContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterDefiniteSchemaPrivLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDefiniteSchemaPrivLevel(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDefiniteFullTablePrivLevel2(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDefiniteFullTablePrivLevel2(this);
		}
	}
	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(MariaDBParser.DOT, 0); }
		public DefiniteFullTablePrivLevelContext(PrivilegeLevelContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterDefiniteFullTablePrivLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDefiniteFullTablePrivLevel(this);
		}
	}
	public static class GlobalPrivLevelContext extends PrivilegeLevelContext {
		public List STAR() { return getTokens(MariaDBParser.STAR); }
		public TerminalNode STAR(int i) {
			return getToken(MariaDBParser.STAR, i);
		}
		public TerminalNode DOT() { return getToken(MariaDBParser.DOT, 0); }
		public GlobalPrivLevelContext(PrivilegeLevelContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterGlobalPrivLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitGlobalPrivLevel(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDefiniteTablePrivLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDefiniteTablePrivLevel(this);
		}
	}
	public static class CurrentSchemaPriviLevelContext extends PrivilegeLevelContext {
		public TerminalNode STAR() { return getToken(MariaDBParser.STAR, 0); }
		public CurrentSchemaPriviLevelContext(PrivilegeLevelContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterCurrentSchemaPriviLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCurrentSchemaPriviLevel(this);
		}
	}

	public final PrivilegeLevelContext privilegeLevel() throws RecognitionException {
		PrivilegeLevelContext _localctx = new PrivilegeLevelContext(_ctx, getState());
		enterRule(_localctx, 472, RULE_privilegeLevel);
		try {
			setState(5709);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,838,_ctx) ) {
			case 1:
				_localctx = new CurrentSchemaPriviLevelContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5693);
				match(STAR);
				}
				break;
			case 2:
				_localctx = new GlobalPrivLevelContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5694);
				match(STAR);
				setState(5695);
				match(DOT);
				setState(5696);
				match(STAR);
				}
				break;
			case 3:
				_localctx = new DefiniteSchemaPrivLevelContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5697);
				uid();
				setState(5698);
				match(DOT);
				setState(5699);
				match(STAR);
				}
				break;
			case 4:
				_localctx = new DefiniteFullTablePrivLevelContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(5701);
				uid();
				setState(5702);
				match(DOT);
				setState(5703);
				uid();
				}
				break;
			case 5:
				_localctx = new DefiniteFullTablePrivLevel2Context(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(5705);
				uid();
				setState(5706);
				dottedId();
				}
				break;
			case 6:
				_localctx = new DefiniteTablePrivLevelContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(5708);
				uid();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class RenameUserClauseContext extends ParserRuleContext {
		public UserNameContext fromFirst;
		public UserNameContext toFirst;
		public TerminalNode TO() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRenameUserClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRenameUserClause(this);
		}
	}

	public final RenameUserClauseContext renameUserClause() throws RecognitionException {
		RenameUserClauseContext _localctx = new RenameUserClauseContext(_ctx, getState());
		enterRule(_localctx, 474, RULE_renameUserClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5711);
			((RenameUserClauseContext)_localctx).fromFirst = userName();
			setState(5712);
			match(TO);
			setState(5713);
			((RenameUserClauseContext)_localctx).toFirst = userName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class AnalyzeTableContext extends ParserRuleContext {
		public Token actionOption;
		public TerminalNode ANALYZE() { return getToken(MariaDBParser.ANALYZE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TerminalNode TABLES() { return getToken(MariaDBParser.TABLES, 0); }
		public TerminalNode UPDATE() { return getToken(MariaDBParser.UPDATE, 0); }
		public List HISTOGRAM() { return getTokens(MariaDBParser.HISTOGRAM); }
		public TerminalNode HISTOGRAM(int i) {
			return getToken(MariaDBParser.HISTOGRAM, i);
		}
		public List ON() { return getTokens(MariaDBParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MariaDBParser.ON, i);
		}
		public List fullColumnName() {
			return getRuleContexts(FullColumnNameContext.class);
		}
		public FullColumnNameContext fullColumnName(int i) {
			return getRuleContext(FullColumnNameContext.class,i);
		}
		public TerminalNode DROP() { return getToken(MariaDBParser.DROP, 0); }
		public TerminalNode NO_WRITE_TO_BINLOG() { return getToken(MariaDBParser.NO_WRITE_TO_BINLOG, 0); }
		public TerminalNode LOCAL() { return getToken(MariaDBParser.LOCAL, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode BUCKETS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAnalyzeTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAnalyzeTable(this);
		}
	}

	public final AnalyzeTableContext analyzeTable() throws RecognitionException {
		AnalyzeTableContext _localctx = new AnalyzeTableContext(_ctx, getState());
		enterRule(_localctx, 476, RULE_analyzeTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5715);
			match(ANALYZE);
			setState(5717);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NO_WRITE_TO_BINLOG || _la==LOCAL) {
				{
				setState(5716);
				((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(5719);
			_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(5720);
			tables();
			setState(5738);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,842,_ctx) ) {
			case 1:
				{
				setState(5721);
				match(UPDATE);
				setState(5722);
				match(HISTOGRAM);
				setState(5723);
				match(ON);
				setState(5724);
				fullColumnName();
				setState(5729);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5725);
					match(COMMA);
					setState(5726);
					fullColumnName();
					}
					}
					setState(5731);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5736);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH) {
					{
					setState(5732);
					match(WITH);
					setState(5733);
					decimalLiteral();
					setState(5734);
					match(BUCKETS);
					}
				}

				}
				break;
			}
			setState(5751);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,844,_ctx) ) {
			case 1:
				{
				setState(5740);
				match(DROP);
				setState(5741);
				match(HISTOGRAM);
				setState(5742);
				match(ON);
				setState(5743);
				fullColumnName();
				setState(5748);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5744);
					match(COMMA);
					setState(5745);
					fullColumnName();
					}
					}
					setState(5750);
					_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;
	}

	public static class CheckTableContext extends ParserRuleContext {
		public TerminalNode CHECK() { return getToken(MariaDBParser.CHECK, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCheckTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCheckTable(this);
		}
	}

	public final CheckTableContext checkTable() throws RecognitionException {
		CheckTableContext _localctx = new CheckTableContext(_ctx, getState());
		enterRule(_localctx, 478, RULE_checkTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5753);
			match(CHECK);
			setState(5754);
			match(TABLE);
			setState(5755);
			tables();
			setState(5759);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==FOR || _la==CHANGED || _la==EXTENDED || _la==FAST || _la==MEDIUM || _la==QUICK) {
				{
				{
				setState(5756);
				checkTableOption();
				}
				}
				setState(5761);
				_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;
	}

	public static class ChecksumTableContext extends ParserRuleContext {
		public Token actionOption;
		public TerminalNode CHECKSUM() { return getToken(MariaDBParser.CHECKSUM, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode QUICK() { return getToken(MariaDBParser.QUICK, 0); }
		public TerminalNode EXTENDED() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterChecksumTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitChecksumTable(this);
		}
	}

	public final ChecksumTableContext checksumTable() throws RecognitionException {
		ChecksumTableContext _localctx = new ChecksumTableContext(_ctx, getState());
		enterRule(_localctx, 480, RULE_checksumTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5762);
			match(CHECKSUM);
			setState(5763);
			match(TABLE);
			setState(5764);
			tables();
			setState(5766);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EXTENDED || _la==QUICK) {
				{
				setState(5765);
				((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;
	}

	public static class OptimizeTableContext extends ParserRuleContext {
		public Token actionOption;
		public TerminalNode OPTIMIZE() { return getToken(MariaDBParser.OPTIMIZE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TerminalNode TABLES() { return getToken(MariaDBParser.TABLES, 0); }
		public WaitNowaitClauseContext waitNowaitClause() {
			return getRuleContext(WaitNowaitClauseContext.class,0);
		}
		public TerminalNode NO_WRITE_TO_BINLOG() { return getToken(MariaDBParser.NO_WRITE_TO_BINLOG, 0); }
		public TerminalNode LOCAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterOptimizeTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitOptimizeTable(this);
		}
	}

	public final OptimizeTableContext optimizeTable() throws RecognitionException {
		OptimizeTableContext _localctx = new OptimizeTableContext(_ctx, getState());
		enterRule(_localctx, 482, RULE_optimizeTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5768);
			match(OPTIMIZE);
			setState(5770);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NO_WRITE_TO_BINLOG || _la==LOCAL) {
				{
				setState(5769);
				((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(5772);
			_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(5773);
			tables();
			setState(5775);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOWAIT || _la==WAIT) {
				{
				setState(5774);
				waitNowaitClause();
				}
			}

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

	public static class RepairTableContext extends ParserRuleContext {
		public Token actionOption;
		public TerminalNode REPAIR() { return getToken(MariaDBParser.REPAIR, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode QUICK() { return getToken(MariaDBParser.QUICK, 0); }
		public TerminalNode EXTENDED() { return getToken(MariaDBParser.EXTENDED, 0); }
		public TerminalNode USE_FRM() { return getToken(MariaDBParser.USE_FRM, 0); }
		public TerminalNode NO_WRITE_TO_BINLOG() { return getToken(MariaDBParser.NO_WRITE_TO_BINLOG, 0); }
		public TerminalNode LOCAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRepairTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRepairTable(this);
		}
	}

	public final RepairTableContext repairTable() throws RecognitionException {
		RepairTableContext _localctx = new RepairTableContext(_ctx, getState());
		enterRule(_localctx, 484, RULE_repairTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5777);
			match(REPAIR);
			setState(5779);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NO_WRITE_TO_BINLOG || _la==LOCAL) {
				{
				setState(5778);
				((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(5781);
			match(TABLE);
			setState(5782);
			tables();
			setState(5784);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==QUICK) {
				{
				setState(5783);
				match(QUICK);
				}
			}

			setState(5787);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EXTENDED) {
				{
				setState(5786);
				match(EXTENDED);
				}
			}

			setState(5790);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==USE_FRM) {
				{
				setState(5789);
				match(USE_FRM);
				}
			}

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

	public static class CheckTableOptionContext extends ParserRuleContext {
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode UPGRADE() { return getToken(MariaDBParser.UPGRADE, 0); }
		public TerminalNode QUICK() { return getToken(MariaDBParser.QUICK, 0); }
		public TerminalNode FAST() { return getToken(MariaDBParser.FAST, 0); }
		public TerminalNode MEDIUM() { return getToken(MariaDBParser.MEDIUM, 0); }
		public TerminalNode EXTENDED() { return getToken(MariaDBParser.EXTENDED, 0); }
		public TerminalNode CHANGED() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCheckTableOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCheckTableOption(this);
		}
	}

	public final CheckTableOptionContext checkTableOption() throws RecognitionException {
		CheckTableOptionContext _localctx = new CheckTableOptionContext(_ctx, getState());
		enterRule(_localctx, 486, RULE_checkTableOption);
		try {
			setState(5799);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case FOR:
				enterOuterAlt(_localctx, 1);
				{
				setState(5792);
				match(FOR);
				setState(5793);
				match(UPGRADE);
				}
				break;
			case QUICK:
				enterOuterAlt(_localctx, 2);
				{
				setState(5794);
				match(QUICK);
				}
				break;
			case FAST:
				enterOuterAlt(_localctx, 3);
				{
				setState(5795);
				match(FAST);
				}
				break;
			case MEDIUM:
				enterOuterAlt(_localctx, 4);
				{
				setState(5796);
				match(MEDIUM);
				}
				break;
			case EXTENDED:
				enterOuterAlt(_localctx, 5);
				{
				setState(5797);
				match(EXTENDED);
				}
				break;
			case CHANGED:
				enterOuterAlt(_localctx, 6);
				{
				setState(5798);
				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;
	}

	public static class CreateUdfunctionContext extends ParserRuleContext {
		public Token returnType;
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode FUNCTION() { return getToken(MariaDBParser.FUNCTION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode RETURNS() { return getToken(MariaDBParser.RETURNS, 0); }
		public TerminalNode SONAME() { return getToken(MariaDBParser.SONAME, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode STRING() { return getToken(MariaDBParser.STRING, 0); }
		public TerminalNode INTEGER() { return getToken(MariaDBParser.INTEGER, 0); }
		public TerminalNode REAL() { return getToken(MariaDBParser.REAL, 0); }
		public TerminalNode DECIMAL() { return getToken(MariaDBParser.DECIMAL, 0); }
		public OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.class,0);
		}
		public TerminalNode AGGREGATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCreateUdfunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCreateUdfunction(this);
		}
	}

	public final CreateUdfunctionContext createUdfunction() throws RecognitionException {
		CreateUdfunctionContext _localctx = new CreateUdfunctionContext(_ctx, getState());
		enterRule(_localctx, 488, RULE_createUdfunction);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5801);
			match(CREATE);
			setState(5803);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OR) {
				{
				setState(5802);
				orReplace();
				}
			}

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

			setState(5808);
			match(FUNCTION);
			setState(5810);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,856,_ctx) ) {
			case 1:
				{
				setState(5809);
				ifNotExists();
				}
				break;
			}
			setState(5812);
			uid();
			setState(5813);
			match(RETURNS);
			setState(5814);
			((CreateUdfunctionContext)_localctx).returnType = _input.LT(1);
			_la = _input.LA(1);
			if ( !(((((_la - 206)) & ~0x3f) == 0 && ((1L << (_la - 206)) & ((1L << (INTEGER - 206)) | (1L << (REAL - 206)) | (1L << (DECIMAL - 206)))) != 0) || _la==STRING) ) {
				((CreateUdfunctionContext)_localctx).returnType = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(5815);
			match(SONAME);
			setState(5816);
			match(STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class InstallPluginContext extends ParserRuleContext {
		public TerminalNode INSTALL() { return getToken(MariaDBParser.INSTALL, 0); }
		public TerminalNode PLUGIN() { return getToken(MariaDBParser.PLUGIN, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode SONAME() { return getToken(MariaDBParser.SONAME, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterInstallPlugin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitInstallPlugin(this);
		}
	}

	public final InstallPluginContext installPlugin() throws RecognitionException {
		InstallPluginContext _localctx = new InstallPluginContext(_ctx, getState());
		enterRule(_localctx, 490, RULE_installPlugin);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5818);
			match(INSTALL);
			setState(5819);
			match(PLUGIN);
			setState(5820);
			uid();
			setState(5821);
			match(SONAME);
			setState(5822);
			match(STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class UninstallPluginContext extends ParserRuleContext {
		public TerminalNode UNINSTALL() { return getToken(MariaDBParser.UNINSTALL, 0); }
		public TerminalNode PLUGIN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUninstallPlugin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUninstallPlugin(this);
		}
	}

	public final UninstallPluginContext uninstallPlugin() throws RecognitionException {
		UninstallPluginContext _localctx = new UninstallPluginContext(_ctx, getState());
		enterRule(_localctx, 492, RULE_uninstallPlugin);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5824);
			match(UNINSTALL);
			setState(5825);
			match(PLUGIN);
			setState(5826);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetTransaction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetTransaction(this);
		}
	}
	public static class SetCharsetContext extends SetStatementContext {
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public CharSetContext charSet() {
			return getRuleContext(CharSetContext.class,0);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public SetCharsetContext(SetStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetCharset(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetCharset(this);
		}
	}
	public static class SetNamesContext extends SetStatementContext {
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode NAMES() { return getToken(MariaDBParser.NAMES, 0); }
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode COLLATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetNames(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetNames(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetPassword(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetPassword(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetAutocommit(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetAutocommit(this);
		}
	}
	public static class SetNewValueInsideTriggerContext extends SetStatementContext {
		public TerminalNode SET() { return getToken(MariaDBParser.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(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.EQUAL_SYMBOL, i);
		}
		public List VAR_ASSIGN() { return getTokens(MariaDBParser.VAR_ASSIGN); }
		public TerminalNode VAR_ASSIGN(int i) {
			return getToken(MariaDBParser.VAR_ASSIGN, i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public SetNewValueInsideTriggerContext(SetStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetNewValueInsideTrigger(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetNewValueInsideTrigger(this);
		}
	}
	public static class SetVariableContext extends SetStatementContext {
		public TerminalNode SET() { return getToken(MariaDBParser.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(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.EQUAL_SYMBOL, i);
		}
		public List VAR_ASSIGN() { return getTokens(MariaDBParser.VAR_ASSIGN); }
		public TerminalNode VAR_ASSIGN(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MariaDBParser.ON, i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public SetVariableContext(SetStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSetVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSetVariable(this);
		}
	}

	public final SetStatementContext setStatement() throws RecognitionException {
		SetStatementContext _localctx = new SetStatementContext(_ctx, getState());
		enterRule(_localctx, 494, RULE_setStatement);
		int _la;
		try {
			setState(5880);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,864,_ctx) ) {
			case 1:
				_localctx = new SetVariableContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5828);
				match(SET);
				setState(5829);
				variableClause();
				setState(5830);
				_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(5833);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,857,_ctx) ) {
				case 1:
					{
					setState(5831);
					expression(0);
					}
					break;
				case 2:
					{
					setState(5832);
					match(ON);
					}
					break;
				}
				setState(5844);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5835);
					match(COMMA);
					setState(5836);
					variableClause();
					setState(5837);
					_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(5840);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,858,_ctx) ) {
					case 1:
						{
						setState(5838);
						expression(0);
						}
						break;
					case 2:
						{
						setState(5839);
						match(ON);
						}
						break;
					}
					}
					}
					setState(5846);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new SetCharsetContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5847);
				match(SET);
				setState(5848);
				charSet();
				setState(5851);
				_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(5849);
					charsetName();
					}
					break;
				case DEFAULT:
					{
					setState(5850);
					match(DEFAULT);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 3:
				_localctx = new SetNamesContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5853);
				match(SET);
				setState(5854);
				match(NAMES);
				setState(5861);
				_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(5855);
					charsetName();
					setState(5858);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==COLLATE) {
						{
						setState(5856);
						match(COLLATE);
						setState(5857);
						collationName();
						}
					}

					}
					break;
				case DEFAULT:
					{
					setState(5860);
					match(DEFAULT);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 4:
				_localctx = new SetPasswordContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(5863);
				setPasswordStatement();
				}
				break;
			case 5:
				_localctx = new SetTransactionContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(5864);
				setTransactionStatement();
				}
				break;
			case 6:
				_localctx = new SetAutocommitContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(5865);
				setAutocommitStatement();
				}
				break;
			case 7:
				_localctx = new SetNewValueInsideTriggerContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(5866);
				match(SET);
				setState(5867);
				fullId();
				setState(5868);
				_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(5869);
				expression(0);
				setState(5877);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5870);
					match(COMMA);
					setState(5871);
					fullId();
					setState(5872);
					_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(5873);
					expression(0);
					}
					}
					setState(5879);
					_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;
	}

	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);
		}
	}
	public static class ShowOpenTablesContext extends ShowStatementContext {
		public Token schemaFormat;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode OPEN() { return getToken(MariaDBParser.OPEN, 0); }
		public TerminalNode TABLES() { return getToken(MariaDBParser.TABLES, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public ShowFilterContext showFilter() {
			return getRuleContext(ShowFilterContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public TerminalNode IN() { return getToken(MariaDBParser.IN, 0); }
		public ShowOpenTablesContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowOpenTables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowOpenTables(this);
		}
	}
	public static class ShowExplainContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode EXPLAIN() { return getToken(MariaDBParser.EXPLAIN, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public FormatJsonStatementContext formatJsonStatement() {
			return getRuleContext(FormatJsonStatementContext.class,0);
		}
		public ShowExplainContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowExplain(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowExplain(this);
		}
	}
	public static class ShowGlobalInfoContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowGlobalInfo(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowGlobalInfo(this);
		}
	}
	public static class ShowCreateFullIdObjectContext extends ShowStatementContext {
		public Token namedEntity;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode EVENT() { return getToken(MariaDBParser.EVENT, 0); }
		public TerminalNode FUNCTION() { return getToken(MariaDBParser.FUNCTION, 0); }
		public TerminalNode PROCEDURE() { return getToken(MariaDBParser.PROCEDURE, 0); }
		public TerminalNode SEQUENCE() { return getToken(MariaDBParser.SEQUENCE, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TerminalNode TRIGGER() { return getToken(MariaDBParser.TRIGGER, 0); }
		public TerminalNode VIEW() { return getToken(MariaDBParser.VIEW, 0); }
		public ShowCreateFullIdObjectContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowCreateFullIdObject(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowCreateFullIdObject(this);
		}
	}
	public static class ShowCreateUserContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode USER() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowCreateUser(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowCreateUser(this);
		}
	}
	public static class ShowErrorsContext extends ShowStatementContext {
		public Token errorFormat;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode ERRORS() { return getToken(MariaDBParser.ERRORS, 0); }
		public TerminalNode WARNINGS() { return getToken(MariaDBParser.WARNINGS, 0); }
		public LimitClauseContext limitClause() {
			return getRuleContext(LimitClauseContext.class,0);
		}
		public ShowErrorsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowErrors(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowErrors(this);
		}
	}
	public static class ShowUserstatPluginContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode USER_STATISTICS() { return getToken(MariaDBParser.USER_STATISTICS, 0); }
		public TerminalNode CLIENT_STATISTICS() { return getToken(MariaDBParser.CLIENT_STATISTICS, 0); }
		public TerminalNode INDEX_STATISTICS() { return getToken(MariaDBParser.INDEX_STATISTICS, 0); }
		public TerminalNode TABLE_STATISTICS() { return getToken(MariaDBParser.TABLE_STATISTICS, 0); }
		public ShowUserstatPluginContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowUserstatPlugin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowUserstatPlugin(this);
		}
	}
	public static class ShowCountErrorsContext extends ShowStatementContext {
		public Token errorFormat;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode COUNT() { return getToken(MariaDBParser.COUNT, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode STAR() { return getToken(MariaDBParser.STAR, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode ERRORS() { return getToken(MariaDBParser.ERRORS, 0); }
		public TerminalNode WARNINGS() { return getToken(MariaDBParser.WARNINGS, 0); }
		public ShowCountErrorsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowCountErrors(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowCountErrors(this);
		}
	}
	public static class ShowObjectFilterContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowObjectFilter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowObjectFilter(this);
		}
	}
	public static class ShowCreateDbContext extends ShowStatementContext {
		public Token schemaFormat;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DATABASE() { return getToken(MariaDBParser.DATABASE, 0); }
		public TerminalNode SCHEMA() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowCreateDb(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowCreateDb(this);
		}
	}
	public static class ShowEngineContext extends ShowStatementContext {
		public Token engineOption;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TerminalNode STATUS() { return getToken(MariaDBParser.STATUS, 0); }
		public TerminalNode MUTEX() { return getToken(MariaDBParser.MUTEX, 0); }
		public ShowEngineContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowEngine(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowEngine(this);
		}
	}
	public static class ShowSchemaFilterContext extends ShowStatementContext {
		public Token schemaFormat;
		public TerminalNode SHOW() { return getToken(MariaDBParser.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(MariaDBParser.FROM, 0); }
		public TerminalNode IN() { return getToken(MariaDBParser.IN, 0); }
		public ShowSchemaFilterContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowSchemaFilter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowSchemaFilter(this);
		}
	}
	public static class ShowInnoDBStatusContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode INNODB() { return getToken(MariaDBParser.INNODB, 0); }
		public TerminalNode STATUS() { return getToken(MariaDBParser.STATUS, 0); }
		public ShowInnoDBStatusContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowInnoDBStatus(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowInnoDBStatus(this);
		}
	}
	public static class ShowIndexesContext extends ShowStatementContext {
		public Token indexFormat;
		public Token tableFormat;
		public Token schemaFormat;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode INDEXES() { return getToken(MariaDBParser.INDEXES, 0); }
		public TerminalNode KEYS() { return getToken(MariaDBParser.KEYS, 0); }
		public List FROM() { return getTokens(MariaDBParser.FROM); }
		public TerminalNode FROM(int i) {
			return getToken(MariaDBParser.FROM, i);
		}
		public List IN() { return getTokens(MariaDBParser.IN); }
		public TerminalNode IN(int i) {
			return getToken(MariaDBParser.IN, i);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode WHERE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowIndexes(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowIndexes(this);
		}
	}
	public static class ShowBinLogEventsContext extends ShowStatementContext {
		public Token filename;
		public DecimalLiteralContext fromPosition;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode BINLOG() { return getToken(MariaDBParser.BINLOG, 0); }
		public TerminalNode EVENTS() { return getToken(MariaDBParser.EVENTS, 0); }
		public TerminalNode IN() { return getToken(MariaDBParser.IN, 0); }
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public LimitClauseContext limitClause() {
			return getRuleContext(LimitClauseContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public ShowBinLogEventsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowBinLogEvents(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowBinLogEvents(this);
		}
	}
	public static class ShowCreatePackageContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode CREATE() { return getToken(MariaDBParser.CREATE, 0); }
		public TerminalNode PACKAGE() { return getToken(MariaDBParser.PACKAGE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode BODY() { return getToken(MariaDBParser.BODY, 0); }
		public ShowCreatePackageContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowCreatePackage(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowCreatePackage(this);
		}
	}
	public static class ShowMasterLogsContext extends ShowStatementContext {
		public Token logFormat;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode LOGS() { return getToken(MariaDBParser.LOGS, 0); }
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public TerminalNode MASTER() { return getToken(MariaDBParser.MASTER, 0); }
		public ShowMasterLogsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowMasterLogs(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowMasterLogs(this);
		}
	}
	public static class ShowGrantsContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode GRANTS() { return getToken(MariaDBParser.GRANTS, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowGrants(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowGrants(this);
		}
	}
	public static class ShowPackageStatusContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode PACKAGE() { return getToken(MariaDBParser.PACKAGE, 0); }
		public TerminalNode STATUS() { return getToken(MariaDBParser.STATUS, 0); }
		public TerminalNode BODY() { return getToken(MariaDBParser.BODY, 0); }
		public ShowFilterContext showFilter() {
			return getRuleContext(ShowFilterContext.class,0);
		}
		public ShowPackageStatusContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowPackageStatus(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowPackageStatus(this);
		}
	}
	public static class ShowSlaveStatusContext extends ShowStatementContext {
		public Token connectionName;
		public Token channelName;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode STATUS() { return getToken(MariaDBParser.STATUS, 0); }
		public TerminalNode SLAVE() { return getToken(MariaDBParser.SLAVE, 0); }
		public TerminalNode REPLICA() { return getToken(MariaDBParser.REPLICA, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode CHANNEL() { return getToken(MariaDBParser.CHANNEL, 0); }
		public List STRING_LITERAL() { return getTokens(MariaDBParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MariaDBParser.STRING_LITERAL, i);
		}
		public ShowSlaveStatusContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowSlaveStatus(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowSlaveStatus(this);
		}
	}
	public static class ShowRoutineContext extends ShowStatementContext {
		public Token routine;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode CODE() { return getToken(MariaDBParser.CODE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode FUNCTION() { return getToken(MariaDBParser.FUNCTION, 0); }
		public TerminalNode PROCEDURE() { return getToken(MariaDBParser.PROCEDURE, 0); }
		public ShowRoutineContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowRoutine(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowRoutine(this);
		}
	}
	public static class ShowProfileContext extends ShowStatementContext {
		public DecimalLiteralContext queryCount;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode PROFILE() { return getToken(MariaDBParser.PROFILE, 0); }
		public List showProfileType() {
			return getRuleContexts(ShowProfileTypeContext.class);
		}
		public ShowProfileTypeContext showProfileType(int i) {
			return getRuleContext(ShowProfileTypeContext.class,i);
		}
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode QUERY() { return getToken(MariaDBParser.QUERY, 0); }
		public LimitClauseContext limitClause() {
			return getRuleContext(LimitClauseContext.class,0);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public ShowProfileContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowProfile(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowProfile(this);
		}
	}
	public static class ShowColumnsContext extends ShowStatementContext {
		public Token columnsFormat;
		public Token tableFormat;
		public Token schemaFormat;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode COLUMNS() { return getToken(MariaDBParser.COLUMNS, 0); }
		public TerminalNode FIELDS() { return getToken(MariaDBParser.FIELDS, 0); }
		public List FROM() { return getTokens(MariaDBParser.FROM); }
		public TerminalNode FROM(int i) {
			return getToken(MariaDBParser.FROM, i);
		}
		public List IN() { return getTokens(MariaDBParser.IN); }
		public TerminalNode IN(int i) {
			return getToken(MariaDBParser.IN, i);
		}
		public TerminalNode FULL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowColumns(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowColumns(this);
		}
	}
	public static class ShowRelayLogEventsContext extends ShowStatementContext {
		public Token connectionName;
		public Token filename;
		public DecimalLiteralContext fromPosition;
		public Token channelName;
		public TerminalNode SHOW() { return getToken(MariaDBParser.SHOW, 0); }
		public TerminalNode RELAYLOG() { return getToken(MariaDBParser.RELAYLOG, 0); }
		public TerminalNode EVENTS() { return getToken(MariaDBParser.EVENTS, 0); }
		public TerminalNode IN() { return getToken(MariaDBParser.IN, 0); }
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public LimitClauseContext limitClause() {
			return getRuleContext(LimitClauseContext.class,0);
		}
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode CHANNEL() { return getToken(MariaDBParser.CHANNEL, 0); }
		public List STRING_LITERAL() { return getTokens(MariaDBParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MariaDBParser.STRING_LITERAL, i);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public ShowRelayLogEventsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowRelayLogEvents(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowRelayLogEvents(this);
		}
	}

	public final ShowStatementContext showStatement() throws RecognitionException {
		ShowStatementContext _localctx = new ShowStatementContext(_ctx, getState());
		enterRule(_localctx, 496, RULE_showStatement);
		int _la;
		try {
			setState(6073);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,896,_ctx) ) {
			case 1:
				_localctx = new ShowMasterLogsContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5882);
				match(SHOW);
				setState(5883);
				((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(5884);
				match(LOGS);
				}
				break;
			case 2:
				_localctx = new ShowBinLogEventsContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5885);
				match(SHOW);
				setState(5886);
				match(BINLOG);
				setState(5887);
				match(EVENTS);
				setState(5890);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IN) {
					{
					setState(5888);
					match(IN);
					setState(5889);
					((ShowBinLogEventsContext)_localctx).filename = match(STRING_LITERAL);
					}
				}

				setState(5894);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM) {
					{
					setState(5892);
					match(FROM);
					setState(5893);
					((ShowBinLogEventsContext)_localctx).fromPosition = decimalLiteral();
					}
				}

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

				}
				break;
			case 3:
				_localctx = new ShowRelayLogEventsContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5899);
				match(SHOW);
				setState(5900);
				match(RELAYLOG);
				setState(5902);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STRING_LITERAL) {
					{
					setState(5901);
					((ShowRelayLogEventsContext)_localctx).connectionName = match(STRING_LITERAL);
					}
				}

				setState(5904);
				match(EVENTS);
				setState(5907);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IN) {
					{
					setState(5905);
					match(IN);
					setState(5906);
					((ShowRelayLogEventsContext)_localctx).filename = match(STRING_LITERAL);
					}
				}

				setState(5911);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM) {
					{
					setState(5909);
					match(FROM);
					setState(5910);
					((ShowRelayLogEventsContext)_localctx).fromPosition = decimalLiteral();
					}
				}

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

				setState(5919);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(5916);
					match(FOR);
					setState(5917);
					match(CHANNEL);
					setState(5918);
					((ShowRelayLogEventsContext)_localctx).channelName = match(STRING_LITERAL);
					}
				}

				}
				break;
			case 4:
				_localctx = new ShowObjectFilterContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(5921);
				match(SHOW);
				setState(5922);
				showCommonEntity();
				setState(5924);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIKE || _la==WHERE) {
					{
					setState(5923);
					showFilter();
					}
				}

				}
				break;
			case 5:
				_localctx = new ShowColumnsContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(5926);
				match(SHOW);
				setState(5928);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FULL) {
					{
					setState(5927);
					match(FULL);
					}
				}

				setState(5930);
				((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(5931);
				((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(5932);
				tableName();
				setState(5935);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM || _la==IN) {
					{
					setState(5933);
					((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(5934);
					uid();
					}
				}

				setState(5938);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIKE || _la==WHERE) {
					{
					setState(5937);
					showFilter();
					}
				}

				}
				break;
			case 6:
				_localctx = new ShowCreateDbContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(5940);
				match(SHOW);
				setState(5941);
				match(CREATE);
				setState(5942);
				((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(5944);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,877,_ctx) ) {
				case 1:
					{
					setState(5943);
					ifNotExists();
					}
					break;
				}
				setState(5946);
				uid();
				}
				break;
			case 7:
				_localctx = new ShowCreateFullIdObjectContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(5947);
				match(SHOW);
				setState(5948);
				match(CREATE);
				setState(5949);
				((ShowCreateFullIdObjectContext)_localctx).namedEntity = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 132)) & ~0x3f) == 0 && ((1L << (_la - 132)) & ((1L << (PROCEDURE - 132)) | (1L << (TABLE - 132)) | (1L << (TRIGGER - 132)))) != 0) || _la==EVENT || _la==FUNCTION || _la==SEQUENCE || _la==VIEW) ) {
					((ShowCreateFullIdObjectContext)_localctx).namedEntity = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5950);
				fullId();
				}
				break;
			case 8:
				_localctx = new ShowCreatePackageContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(5951);
				match(SHOW);
				setState(5952);
				match(CREATE);
				setState(5953);
				match(PACKAGE);
				setState(5955);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,878,_ctx) ) {
				case 1:
					{
					setState(5954);
					match(BODY);
					}
					break;
				}
				setState(5957);
				fullId();
				}
				break;
			case 9:
				_localctx = new ShowCreateUserContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(5958);
				match(SHOW);
				setState(5959);
				match(CREATE);
				setState(5960);
				match(USER);
				setState(5961);
				userName();
				}
				break;
			case 10:
				_localctx = new ShowEngineContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(5962);
				match(SHOW);
				setState(5963);
				match(ENGINE);
				setState(5964);
				engineName();
				setState(5965);
				((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 11:
				_localctx = new ShowInnoDBStatusContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(5967);
				match(SHOW);
				setState(5968);
				match(INNODB);
				setState(5969);
				match(STATUS);
				}
				break;
			case 12:
				_localctx = new ShowGlobalInfoContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(5970);
				match(SHOW);
				setState(5971);
				showGlobalInfoClause();
				}
				break;
			case 13:
				_localctx = new ShowErrorsContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(5972);
				match(SHOW);
				setState(5973);
				((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(5975);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIMIT) {
					{
					setState(5974);
					limitClause();
					}
				}

				}
				break;
			case 14:
				_localctx = new ShowCountErrorsContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(5977);
				match(SHOW);
				setState(5978);
				match(COUNT);
				setState(5979);
				match(LR_BRACKET);
				setState(5980);
				match(STAR);
				setState(5981);
				match(RR_BRACKET);
				setState(5982);
				((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 15:
				_localctx = new ShowSchemaFilterContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(5983);
				match(SHOW);
				setState(5984);
				showSchemaEntity();
				setState(5987);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM || _la==IN) {
					{
					setState(5985);
					((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(5986);
					uid();
					}
				}

				setState(5990);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIKE || _la==WHERE) {
					{
					setState(5989);
					showFilter();
					}
				}

				}
				break;
			case 16:
				_localctx = new ShowRoutineContext(_localctx);
				enterOuterAlt(_localctx, 16);
				{
				setState(5992);
				match(SHOW);
				setState(5993);
				((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(5994);
				match(CODE);
				setState(5995);
				fullId();
				}
				break;
			case 17:
				_localctx = new ShowGrantsContext(_localctx);
				enterOuterAlt(_localctx, 17);
				{
				setState(5996);
				match(SHOW);
				setState(5997);
				match(GRANTS);
				setState(6000);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(5998);
					match(FOR);
					setState(5999);
					userName();
					}
				}

				}
				break;
			case 18:
				_localctx = new ShowIndexesContext(_localctx);
				enterOuterAlt(_localctx, 18);
				{
				setState(6002);
				match(SHOW);
				setState(6003);
				((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(6004);
				((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(6005);
				tableName();
				setState(6008);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM || _la==IN) {
					{
					setState(6006);
					((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(6007);
					uid();
					}
				}

				setState(6012);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WHERE) {
					{
					setState(6010);
					match(WHERE);
					setState(6011);
					expression(0);
					}
				}

				}
				break;
			case 19:
				_localctx = new ShowOpenTablesContext(_localctx);
				enterOuterAlt(_localctx, 19);
				{
				setState(6014);
				match(SHOW);
				setState(6015);
				match(OPEN);
				setState(6016);
				match(TABLES);
				setState(6019);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM || _la==IN) {
					{
					setState(6017);
					((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(6018);
					fullId();
					}
				}

				setState(6022);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIKE || _la==WHERE) {
					{
					setState(6021);
					showFilter();
					}
				}

				}
				break;
			case 20:
				_localctx = new ShowProfileContext(_localctx);
				enterOuterAlt(_localctx, 20);
				{
				setState(6024);
				match(SHOW);
				setState(6025);
				match(PROFILE);
				setState(6034);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ALL || ((((_la - 347)) & ~0x3f) == 0 && ((1L << (_la - 347)) & ((1L << (BLOCK - 347)) | (1L << (CONTEXT - 347)) | (1L << (CPU - 347)))) != 0) || _la==IPC || _la==PAGE || _la==SOURCE || _la==SWAPS || _la==MEMORY) {
					{
					setState(6026);
					showProfileType();
					setState(6031);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(6027);
						match(COMMA);
						setState(6028);
						showProfileType();
						}
						}
						setState(6033);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				setState(6039);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(6036);
					match(FOR);
					setState(6037);
					match(QUERY);
					setState(6038);
					((ShowProfileContext)_localctx).queryCount = decimalLiteral();
					}
				}

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

				}
				break;
			case 21:
				_localctx = new ShowSlaveStatusContext(_localctx);
				enterOuterAlt(_localctx, 21);
				{
				setState(6044);
				match(SHOW);
				setState(6045);
				_la = _input.LA(1);
				if ( !(_la==SLAVE || _la==REPLICA) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6047);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STRING_LITERAL) {
					{
					setState(6046);
					((ShowSlaveStatusContext)_localctx).connectionName = match(STRING_LITERAL);
					}
				}

				setState(6049);
				match(STATUS);
				setState(6053);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(6050);
					match(FOR);
					setState(6051);
					match(CHANNEL);
					setState(6052);
					((ShowSlaveStatusContext)_localctx).channelName = match(STRING_LITERAL);
					}
				}

				}
				break;
			case 22:
				_localctx = new ShowUserstatPluginContext(_localctx);
				enterOuterAlt(_localctx, 22);
				{
				setState(6055);
				match(SHOW);
				setState(6056);
				_la = _input.LA(1);
				if ( !(((((_la - 703)) & ~0x3f) == 0 && ((1L << (_la - 703)) & ((1L << (USER_STATISTICS - 703)) | (1L << (CLIENT_STATISTICS - 703)) | (1L << (INDEX_STATISTICS - 703)) | (1L << (TABLE_STATISTICS - 703)))) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 23:
				_localctx = new ShowExplainContext(_localctx);
				enterOuterAlt(_localctx, 23);
				{
				setState(6057);
				match(SHOW);
				setState(6058);
				match(EXPLAIN);
				setState(6060);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FORMAT) {
					{
					setState(6059);
					formatJsonStatement();
					}
				}

				setState(6062);
				match(FOR);
				setState(6063);
				decimalLiteral();
				}
				break;
			case 24:
				_localctx = new ShowPackageStatusContext(_localctx);
				enterOuterAlt(_localctx, 24);
				{
				setState(6064);
				match(SHOW);
				setState(6065);
				match(PACKAGE);
				setState(6067);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==BODY) {
					{
					setState(6066);
					match(BODY);
					}
				}

				setState(6069);
				match(STATUS);
				setState(6071);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIKE || _la==WHERE) {
					{
					setState(6070);
					showFilter();
					}
				}

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

	public static class ExplainStatementContext extends ParserRuleContext {
		public ExplainStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_explainStatement; }
	 
		public ExplainStatementContext() { }
		public void copyFrom(ExplainStatementContext ctx) {
			super.copyFrom(ctx);
		}
	}
	public static class ExplainForConnectionContext extends ExplainStatementContext {
		public TerminalNode EXPLAIN() { return getToken(MariaDBParser.EXPLAIN, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode CONNECTION() { return getToken(MariaDBParser.CONNECTION, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public FormatJsonStatementContext formatJsonStatement() {
			return getRuleContext(FormatJsonStatementContext.class,0);
		}
		public ExplainForConnectionContext(ExplainStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterExplainForConnection(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitExplainForConnection(this);
		}
	}

	public final ExplainStatementContext explainStatement() throws RecognitionException {
		ExplainStatementContext _localctx = new ExplainStatementContext(_ctx, getState());
		enterRule(_localctx, 498, RULE_explainStatement);
		int _la;
		try {
			_localctx = new ExplainForConnectionContext(_localctx);
			enterOuterAlt(_localctx, 1);
			{
			setState(6075);
			match(EXPLAIN);
			setState(6077);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FORMAT) {
				{
				setState(6076);
				formatJsonStatement();
				}
			}

			setState(6079);
			match(FOR);
			setState(6080);
			match(CONNECTION);
			setState(6081);
			decimalLiteral();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class VariableClauseContext extends ParserRuleContext {
		public TerminalNode LOCAL_ID() { return getToken(MariaDBParser.LOCAL_ID, 0); }
		public TerminalNode GLOBAL_ID() { return getToken(MariaDBParser.GLOBAL_ID, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode GLOBAL() { return getToken(MariaDBParser.GLOBAL, 0); }
		public TerminalNode SESSION() { return getToken(MariaDBParser.SESSION, 0); }
		public TerminalNode LOCAL() { return getToken(MariaDBParser.LOCAL, 0); }
		public List AT_SIGN() { return getTokens(MariaDBParser.AT_SIGN); }
		public TerminalNode AT_SIGN(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterVariableClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitVariableClause(this);
		}
	}

	public final VariableClauseContext variableClause() throws RecognitionException {
		VariableClauseContext _localctx = new VariableClauseContext(_ctx, getState());
		enterRule(_localctx, 500, RULE_variableClause);
		int _la;
		try {
			setState(6093);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_ID:
				enterOuterAlt(_localctx, 1);
				{
				setState(6083);
				match(LOCAL_ID);
				}
				break;
			case GLOBAL_ID:
				enterOuterAlt(_localctx, 2);
				{
				setState(6084);
				match(GLOBAL_ID);
				}
				break;
			case ATTRIBUTE:
			case BODY:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_ROLE:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case LOCKED:
			case MAXVALUE:
			case MINVALUE:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case PACKAGE:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_:
			case STACKED:
			case STATEMENT:
			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 CYCLE:
			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 ENCRYPTED:
			case ENCRYPTION:
			case ENCRYPTION_KEY_ID:
			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 INCREMENT:
			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 LOCALES:
			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 NOCACHE:
			case NOCOPY:
			case NOCYCLE:
			case NOMAXVALUE:
			case NOMINVALUE:
			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 QUERY_RESPONSE_TIME:
			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 RESTART:
			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 SEQUENCE:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLAVES:
			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 TYPES:
			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 WSREP_MEMBERSHIP:
			case WSREP_STATUS:
			case X509:
			case XA:
			case XML:
			case YES:
			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 USER_STATISTICS:
			case CLIENT_STATISTICS:
			case INDEX_STATISTICS:
			case TABLE_STATISTICS:
			case ADMIN:
			case AUDIT_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_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_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 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 VIA:
			case LASTVAL:
			case NEXTVAL:
			case SETVAL:
			case PREVIOUS:
			case PERSISTENT:
			case BINLOG_MONITOR:
			case BINLOG_REPLAY:
			case FEDERATED_ADMIN:
			case READ_ONLY_ADMIN:
			case REPLICA:
			case REPLICAS:
			case REPLICATION_MASTER_ADMIN:
			case MONITOR:
			case READ_ONLY:
			case REPLAY:
			case MOD:
			case AT_SIGN:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				enterOuterAlt(_localctx, 3);
				{
				setState(6090);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,899,_ctx) ) {
				case 1:
					{
					setState(6087);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AT_SIGN) {
						{
						setState(6085);
						match(AT_SIGN);
						setState(6086);
						match(AT_SIGN);
						}
					}

					setState(6089);
					_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(6092);
				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;
	}

	public static class ShowCommonEntityContext extends ParserRuleContext {
		public TerminalNode CHARACTER() { return getToken(MariaDBParser.CHARACTER, 0); }
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode COLLATION() { return getToken(MariaDBParser.COLLATION, 0); }
		public TerminalNode DATABASES() { return getToken(MariaDBParser.DATABASES, 0); }
		public TerminalNode SCHEMAS() { return getToken(MariaDBParser.SCHEMAS, 0); }
		public TerminalNode FUNCTION() { return getToken(MariaDBParser.FUNCTION, 0); }
		public TerminalNode STATUS() { return getToken(MariaDBParser.STATUS, 0); }
		public TerminalNode PROCEDURE() { return getToken(MariaDBParser.PROCEDURE, 0); }
		public TerminalNode VARIABLES() { return getToken(MariaDBParser.VARIABLES, 0); }
		public TerminalNode GLOBAL() { return getToken(MariaDBParser.GLOBAL, 0); }
		public TerminalNode SESSION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowCommonEntity(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowCommonEntity(this);
		}
	}

	public final ShowCommonEntityContext showCommonEntity() throws RecognitionException {
		ShowCommonEntityContext _localctx = new ShowCommonEntityContext(_ctx, getState());
		enterRule(_localctx, 502, RULE_showCommonEntity);
		int _la;
		try {
			setState(6108);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CHARACTER:
				enterOuterAlt(_localctx, 1);
				{
				setState(6095);
				match(CHARACTER);
				setState(6096);
				match(SET);
				}
				break;
			case COLLATION:
				enterOuterAlt(_localctx, 2);
				{
				setState(6097);
				match(COLLATION);
				}
				break;
			case DATABASES:
				enterOuterAlt(_localctx, 3);
				{
				setState(6098);
				match(DATABASES);
				}
				break;
			case SCHEMAS:
				enterOuterAlt(_localctx, 4);
				{
				setState(6099);
				match(SCHEMAS);
				}
				break;
			case FUNCTION:
				enterOuterAlt(_localctx, 5);
				{
				setState(6100);
				match(FUNCTION);
				setState(6101);
				match(STATUS);
				}
				break;
			case PROCEDURE:
				enterOuterAlt(_localctx, 6);
				{
				setState(6102);
				match(PROCEDURE);
				setState(6103);
				match(STATUS);
				}
				break;
			case GLOBAL:
			case SESSION:
			case STATUS:
			case VARIABLES:
				enterOuterAlt(_localctx, 7);
				{
				setState(6105);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==GLOBAL || _la==SESSION) {
					{
					setState(6104);
					_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(6107);
				_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;
	}

	public static class ShowFilterContext extends ParserRuleContext {
		public TerminalNode LIKE() { return getToken(MariaDBParser.LIKE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode WHERE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowFilter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowFilter(this);
		}
	}

	public final ShowFilterContext showFilter() throws RecognitionException {
		ShowFilterContext _localctx = new ShowFilterContext(_ctx, getState());
		enterRule(_localctx, 504, RULE_showFilter);
		try {
			setState(6114);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LIKE:
				enterOuterAlt(_localctx, 1);
				{
				setState(6110);
				match(LIKE);
				setState(6111);
				match(STRING_LITERAL);
				}
				break;
			case WHERE:
				enterOuterAlt(_localctx, 2);
				{
				setState(6112);
				match(WHERE);
				setState(6113);
				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;
	}

	public static class ShowGlobalInfoClauseContext extends ParserRuleContext {
		public TerminalNode ENGINES() { return getToken(MariaDBParser.ENGINES, 0); }
		public TerminalNode STORAGE() { return getToken(MariaDBParser.STORAGE, 0); }
		public TerminalNode STATUS() { return getToken(MariaDBParser.STATUS, 0); }
		public TerminalNode MASTER() { return getToken(MariaDBParser.MASTER, 0); }
		public TerminalNode BINLOG() { return getToken(MariaDBParser.BINLOG, 0); }
		public TerminalNode PLUGINS() { return getToken(MariaDBParser.PLUGINS, 0); }
		public TerminalNode SONAME() { return getToken(MariaDBParser.SONAME, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public ShowFilterContext showFilter() {
			return getRuleContext(ShowFilterContext.class,0);
		}
		public TerminalNode PRIVILEGES() { return getToken(MariaDBParser.PRIVILEGES, 0); }
		public TerminalNode PROCESSLIST() { return getToken(MariaDBParser.PROCESSLIST, 0); }
		public TerminalNode FULL() { return getToken(MariaDBParser.FULL, 0); }
		public TerminalNode PROFILES() { return getToken(MariaDBParser.PROFILES, 0); }
		public TerminalNode LOCALES() { return getToken(MariaDBParser.LOCALES, 0); }
		public TerminalNode HOSTS() { return getToken(MariaDBParser.HOSTS, 0); }
		public TerminalNode SLAVE() { return getToken(MariaDBParser.SLAVE, 0); }
		public TerminalNode REPLICA() { return getToken(MariaDBParser.REPLICA, 0); }
		public TerminalNode AUTHORS() { return getToken(MariaDBParser.AUTHORS, 0); }
		public TerminalNode CONTRIBUTORS() { return getToken(MariaDBParser.CONTRIBUTORS, 0); }
		public TerminalNode QUERY_RESPONSE_TIME() { return getToken(MariaDBParser.QUERY_RESPONSE_TIME, 0); }
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public TerminalNode SLAVES() { return getToken(MariaDBParser.SLAVES, 0); }
		public TerminalNode REPLICAS() { return getToken(MariaDBParser.REPLICAS, 0); }
		public TerminalNode WSREP_MEMBERSHIP() { return getToken(MariaDBParser.WSREP_MEMBERSHIP, 0); }
		public TerminalNode WSREP_STATUS() { return getToken(MariaDBParser.WSREP_STATUS, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TerminalNode TYPES() { return getToken(MariaDBParser.TYPES, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowGlobalInfoClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowGlobalInfoClause(this);
		}
	}

	public final ShowGlobalInfoClauseContext showGlobalInfoClause() throws RecognitionException {
		ShowGlobalInfoClauseContext _localctx = new ShowGlobalInfoClauseContext(_ctx, getState());
		enterRule(_localctx, 506, RULE_showGlobalInfoClause);
		int _la;
		try {
			setState(6149);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ENGINES:
			case STORAGE:
				enterOuterAlt(_localctx, 1);
				{
				setState(6117);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STORAGE) {
					{
					setState(6116);
					match(STORAGE);
					}
				}

				setState(6119);
				match(ENGINES);
				}
				break;
			case BINLOG:
			case MASTER:
				enterOuterAlt(_localctx, 2);
				{
				setState(6120);
				_la = _input.LA(1);
				if ( !(_la==BINLOG || _la==MASTER) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6121);
				match(STATUS);
				}
				break;
			case PLUGINS:
				enterOuterAlt(_localctx, 3);
				{
				setState(6122);
				match(PLUGINS);
				setState(6128);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==SONAME) {
					{
					setState(6123);
					match(SONAME);
					setState(6126);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case STRING_LITERAL:
						{
						setState(6124);
						match(STRING_LITERAL);
						}
						break;
					case LIKE:
					case WHERE:
						{
						setState(6125);
						showFilter();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
				}

				}
				break;
			case PRIVILEGES:
				enterOuterAlt(_localctx, 4);
				{
				setState(6130);
				match(PRIVILEGES);
				}
				break;
			case FULL:
			case PROCESSLIST:
				enterOuterAlt(_localctx, 5);
				{
				setState(6132);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FULL) {
					{
					setState(6131);
					match(FULL);
					}
				}

				setState(6134);
				match(PROCESSLIST);
				}
				break;
			case PROFILES:
				enterOuterAlt(_localctx, 6);
				{
				setState(6135);
				match(PROFILES);
				}
				break;
			case LOCALES:
				enterOuterAlt(_localctx, 7);
				{
				setState(6136);
				match(LOCALES);
				}
				break;
			case SLAVE:
			case REPLICA:
				enterOuterAlt(_localctx, 8);
				{
				setState(6137);
				_la = _input.LA(1);
				if ( !(_la==SLAVE || _la==REPLICA) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6138);
				match(HOSTS);
				}
				break;
			case AUTHORS:
				enterOuterAlt(_localctx, 9);
				{
				setState(6139);
				match(AUTHORS);
				}
				break;
			case CONTRIBUTORS:
				enterOuterAlt(_localctx, 10);
				{
				setState(6140);
				match(CONTRIBUTORS);
				}
				break;
			case QUERY_RESPONSE_TIME:
				enterOuterAlt(_localctx, 11);
				{
				setState(6141);
				match(QUERY_RESPONSE_TIME);
				}
				break;
			case ALL:
				enterOuterAlt(_localctx, 12);
				{
				setState(6142);
				match(ALL);
				setState(6143);
				_la = _input.LA(1);
				if ( !(_la==SLAVES || _la==REPLICAS) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6144);
				match(STATUS);
				}
				break;
			case WSREP_MEMBERSHIP:
				enterOuterAlt(_localctx, 13);
				{
				setState(6145);
				match(WSREP_MEMBERSHIP);
				}
				break;
			case WSREP_STATUS:
				enterOuterAlt(_localctx, 14);
				{
				setState(6146);
				match(WSREP_STATUS);
				}
				break;
			case TABLE:
				enterOuterAlt(_localctx, 15);
				{
				setState(6147);
				match(TABLE);
				setState(6148);
				match(TYPES);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ShowSchemaEntityContext extends ParserRuleContext {
		public TerminalNode EVENTS() { return getToken(MariaDBParser.EVENTS, 0); }
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TerminalNode STATUS() { return getToken(MariaDBParser.STATUS, 0); }
		public TerminalNode TABLES() { return getToken(MariaDBParser.TABLES, 0); }
		public TerminalNode FULL() { return getToken(MariaDBParser.FULL, 0); }
		public TerminalNode TRIGGERS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowSchemaEntity(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowSchemaEntity(this);
		}
	}

	public final ShowSchemaEntityContext showSchemaEntity() throws RecognitionException {
		ShowSchemaEntityContext _localctx = new ShowSchemaEntityContext(_ctx, getState());
		enterRule(_localctx, 508, RULE_showSchemaEntity);
		int _la;
		try {
			setState(6159);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case EVENTS:
				enterOuterAlt(_localctx, 1);
				{
				setState(6151);
				match(EVENTS);
				}
				break;
			case TABLE:
				enterOuterAlt(_localctx, 2);
				{
				setState(6152);
				match(TABLE);
				setState(6153);
				match(STATUS);
				}
				break;
			case FULL:
			case TABLES:
				enterOuterAlt(_localctx, 3);
				{
				setState(6155);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FULL) {
					{
					setState(6154);
					match(FULL);
					}
				}

				setState(6157);
				match(TABLES);
				}
				break;
			case TRIGGERS:
				enterOuterAlt(_localctx, 4);
				{
				setState(6158);
				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;
	}

	public static class ShowProfileTypeContext extends ParserRuleContext {
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public TerminalNode BLOCK() { return getToken(MariaDBParser.BLOCK, 0); }
		public TerminalNode IO() { return getToken(MariaDBParser.IO, 0); }
		public TerminalNode CONTEXT() { return getToken(MariaDBParser.CONTEXT, 0); }
		public TerminalNode SWITCHES() { return getToken(MariaDBParser.SWITCHES, 0); }
		public TerminalNode CPU() { return getToken(MariaDBParser.CPU, 0); }
		public TerminalNode IPC() { return getToken(MariaDBParser.IPC, 0); }
		public TerminalNode MEMORY() { return getToken(MariaDBParser.MEMORY, 0); }
		public TerminalNode PAGE() { return getToken(MariaDBParser.PAGE, 0); }
		public TerminalNode FAULTS() { return getToken(MariaDBParser.FAULTS, 0); }
		public TerminalNode SOURCE() { return getToken(MariaDBParser.SOURCE, 0); }
		public TerminalNode SWAPS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShowProfileType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShowProfileType(this);
		}
	}

	public final ShowProfileTypeContext showProfileType() throws RecognitionException {
		ShowProfileTypeContext _localctx = new ShowProfileTypeContext(_ctx, getState());
		enterRule(_localctx, 510, RULE_showProfileType);
		try {
			setState(6173);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ALL:
				enterOuterAlt(_localctx, 1);
				{
				setState(6161);
				match(ALL);
				}
				break;
			case BLOCK:
				enterOuterAlt(_localctx, 2);
				{
				setState(6162);
				match(BLOCK);
				setState(6163);
				match(IO);
				}
				break;
			case CONTEXT:
				enterOuterAlt(_localctx, 3);
				{
				setState(6164);
				match(CONTEXT);
				setState(6165);
				match(SWITCHES);
				}
				break;
			case CPU:
				enterOuterAlt(_localctx, 4);
				{
				setState(6166);
				match(CPU);
				}
				break;
			case IPC:
				enterOuterAlt(_localctx, 5);
				{
				setState(6167);
				match(IPC);
				}
				break;
			case MEMORY:
				enterOuterAlt(_localctx, 6);
				{
				setState(6168);
				match(MEMORY);
				}
				break;
			case PAGE:
				enterOuterAlt(_localctx, 7);
				{
				setState(6169);
				match(PAGE);
				setState(6170);
				match(FAULTS);
				}
				break;
			case SOURCE:
				enterOuterAlt(_localctx, 8);
				{
				setState(6171);
				match(SOURCE);
				}
				break;
			case SWAPS:
				enterOuterAlt(_localctx, 9);
				{
				setState(6172);
				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;
	}

	public static class BinlogStatementContext extends ParserRuleContext {
		public TerminalNode BINLOG() { return getToken(MariaDBParser.BINLOG, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterBinlogStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitBinlogStatement(this);
		}
	}

	public final BinlogStatementContext binlogStatement() throws RecognitionException {
		BinlogStatementContext _localctx = new BinlogStatementContext(_ctx, getState());
		enterRule(_localctx, 512, RULE_binlogStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6175);
			match(BINLOG);
			setState(6176);
			match(STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CacheIndexStatementContext extends ParserRuleContext {
		public UidContext schema;
		public TerminalNode CACHE() { return getToken(MariaDBParser.CACHE, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public List tableIndexes() {
			return getRuleContexts(TableIndexesContext.class);
		}
		public TableIndexesContext tableIndexes(int i) {
			return getRuleContext(TableIndexesContext.class,i);
		}
		public TerminalNode IN() { return getToken(MariaDBParser.IN, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCacheIndexStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCacheIndexStatement(this);
		}
	}

	public final CacheIndexStatementContext cacheIndexStatement() throws RecognitionException {
		CacheIndexStatementContext _localctx = new CacheIndexStatementContext(_ctx, getState());
		enterRule(_localctx, 514, RULE_cacheIndexStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6178);
			match(CACHE);
			setState(6179);
			match(INDEX);
			setState(6180);
			tableIndexes();
			setState(6185);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6181);
				match(COMMA);
				setState(6182);
				tableIndexes();
				}
				}
				setState(6187);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(6195);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(6188);
				match(PARTITION);
				setState(6189);
				match(LR_BRACKET);
				setState(6192);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(6190);
					uidList();
					}
					break;
				case ALL:
					{
					setState(6191);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(6194);
				match(RR_BRACKET);
				}
			}

			setState(6197);
			match(IN);
			setState(6198);
			((CacheIndexStatementContext)_localctx).schema = uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class FlushStatementContext extends ParserRuleContext {
		public Token flushFormat;
		public TerminalNode FLUSH() { return getToken(MariaDBParser.FLUSH, 0); }
		public List flushOption() {
			return getRuleContexts(FlushOptionContext.class);
		}
		public FlushOptionContext flushOption(int i) {
			return getRuleContext(FlushOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode NO_WRITE_TO_BINLOG() { return getToken(MariaDBParser.NO_WRITE_TO_BINLOG, 0); }
		public TerminalNode LOCAL() { return getToken(MariaDBParser.LOCAL, 0); }
		public TerminalNode USER_STATISTICS() { return getToken(MariaDBParser.USER_STATISTICS, 0); }
		public TerminalNode CLIENT_STATISTICS() { return getToken(MariaDBParser.CLIENT_STATISTICS, 0); }
		public TerminalNode INDEX_STATISTICS() { return getToken(MariaDBParser.INDEX_STATISTICS, 0); }
		public TerminalNode TABLE_STATISTICS() { return getToken(MariaDBParser.TABLE_STATISTICS, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFlushStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFlushStatement(this);
		}
	}

	public final FlushStatementContext flushStatement() throws RecognitionException {
		FlushStatementContext _localctx = new FlushStatementContext(_ctx, getState());
		enterRule(_localctx, 516, RULE_flushStatement);
		int _la;
		try {
			setState(6214);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,917,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6200);
				match(FLUSH);
				setState(6202);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NO_WRITE_TO_BINLOG || _la==LOCAL) {
					{
					setState(6201);
					((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(6204);
				flushOption();
				setState(6209);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(6205);
					match(COMMA);
					setState(6206);
					flushOption();
					}
					}
					setState(6211);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6212);
				match(FLUSH);
				setState(6213);
				_la = _input.LA(1);
				if ( !(((((_la - 703)) & ~0x3f) == 0 && ((1L << (_la - 703)) & ((1L << (USER_STATISTICS - 703)) | (1L << (CLIENT_STATISTICS - 703)) | (1L << (INDEX_STATISTICS - 703)) | (1L << (TABLE_STATISTICS - 703)))) != 0)) ) {
				_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;
	}

	public static class KillStatementContext extends ParserRuleContext {
		public Token connectionFormat;
		public TerminalNode KILL() { return getToken(MariaDBParser.KILL, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode CONNECTION() { return getToken(MariaDBParser.CONNECTION, 0); }
		public TerminalNode QUERY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterKillStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitKillStatement(this);
		}
	}

	public final KillStatementContext killStatement() throws RecognitionException {
		KillStatementContext _localctx = new KillStatementContext(_ctx, getState());
		enterRule(_localctx, 518, RULE_killStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6216);
			match(KILL);
			setState(6218);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,918,_ctx) ) {
			case 1:
				{
				setState(6217);
				((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(6220);
			expression(0);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class LoadIndexIntoCacheContext extends ParserRuleContext {
		public TerminalNode LOAD() { return getToken(MariaDBParser.LOAD, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode INTO() { return getToken(MariaDBParser.INTO, 0); }
		public TerminalNode CACHE() { return getToken(MariaDBParser.CACHE, 0); }
		public List loadedTableIndexes() {
			return getRuleContexts(LoadedTableIndexesContext.class);
		}
		public LoadedTableIndexesContext loadedTableIndexes(int i) {
			return getRuleContext(LoadedTableIndexesContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLoadIndexIntoCache(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLoadIndexIntoCache(this);
		}
	}

	public final LoadIndexIntoCacheContext loadIndexIntoCache() throws RecognitionException {
		LoadIndexIntoCacheContext _localctx = new LoadIndexIntoCacheContext(_ctx, getState());
		enterRule(_localctx, 520, RULE_loadIndexIntoCache);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6222);
			match(LOAD);
			setState(6223);
			match(INDEX);
			setState(6224);
			match(INTO);
			setState(6225);
			match(CACHE);
			setState(6226);
			loadedTableIndexes();
			setState(6231);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6227);
				match(COMMA);
				setState(6228);
				loadedTableIndexes();
				}
				}
				setState(6233);
				_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;
	}

	public static class ResetStatementContext extends ParserRuleContext {
		public TerminalNode RESET() { return getToken(MariaDBParser.RESET, 0); }
		public TerminalNode QUERY() { return getToken(MariaDBParser.QUERY, 0); }
		public TerminalNode CACHE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterResetStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitResetStatement(this);
		}
	}

	public final ResetStatementContext resetStatement() throws RecognitionException {
		ResetStatementContext _localctx = new ResetStatementContext(_ctx, getState());
		enterRule(_localctx, 522, RULE_resetStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6234);
			match(RESET);
			setState(6235);
			match(QUERY);
			setState(6236);
			match(CACHE);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ShutdownStatementContext extends ParserRuleContext {
		public TerminalNode SHUTDOWN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterShutdownStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitShutdownStatement(this);
		}
	}

	public final ShutdownStatementContext shutdownStatement() throws RecognitionException {
		ShutdownStatementContext _localctx = new ShutdownStatementContext(_ctx, getState());
		enterRule(_localctx, 524, RULE_shutdownStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6238);
			match(SHUTDOWN);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class TableIndexesContext extends ParserRuleContext {
		public Token indexFormat;
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableIndexes(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableIndexes(this);
		}
	}

	public final TableIndexesContext tableIndexes() throws RecognitionException {
		TableIndexesContext _localctx = new TableIndexesContext(_ctx, getState());
		enterRule(_localctx, 526, RULE_tableIndexes);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6240);
			tableName();
			setState(6248);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INDEX || _la==KEY || _la==LR_BRACKET) {
				{
				setState(6242);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INDEX || _la==KEY) {
					{
					setState(6241);
					((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(6244);
				match(LR_BRACKET);
				setState(6245);
				uidList();
				setState(6246);
				match(RR_BRACKET);
				}
			}

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

	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);
		}
	}
	public static class TableFlushOptionContext extends FlushOptionContext {
		public TerminalNode TABLE() { return getToken(MariaDBParser.TABLE, 0); }
		public TerminalNode TABLES() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableFlushOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableFlushOption(this);
		}
	}
	public static class ChannelFlushOptionContext extends FlushOptionContext {
		public TerminalNode RELAY() { return getToken(MariaDBParser.RELAY, 0); }
		public TerminalNode LOGS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterChannelFlushOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitChannelFlushOption(this);
		}
	}
	public static class SimpleFlushOptionContext extends FlushOptionContext {
		public TerminalNode DES_KEY_FILE() { return getToken(MariaDBParser.DES_KEY_FILE, 0); }
		public TerminalNode HOSTS() { return getToken(MariaDBParser.HOSTS, 0); }
		public TerminalNode LOGS() { return getToken(MariaDBParser.LOGS, 0); }
		public TerminalNode OPTIMIZER_COSTS() { return getToken(MariaDBParser.OPTIMIZER_COSTS, 0); }
		public TerminalNode PRIVILEGES() { return getToken(MariaDBParser.PRIVILEGES, 0); }
		public TerminalNode QUERY() { return getToken(MariaDBParser.QUERY, 0); }
		public TerminalNode CACHE() { return getToken(MariaDBParser.CACHE, 0); }
		public TerminalNode STATUS() { return getToken(MariaDBParser.STATUS, 0); }
		public TerminalNode USER_RESOURCES() { return getToken(MariaDBParser.USER_RESOURCES, 0); }
		public TerminalNode TABLES() { return getToken(MariaDBParser.TABLES, 0); }
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public TerminalNode READ() { return getToken(MariaDBParser.READ, 0); }
		public TerminalNode LOCK() { return getToken(MariaDBParser.LOCK, 0); }
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public TerminalNode ERROR() { return getToken(MariaDBParser.ERROR, 0); }
		public TerminalNode GENERAL() { return getToken(MariaDBParser.GENERAL, 0); }
		public TerminalNode RELAY() { return getToken(MariaDBParser.RELAY, 0); }
		public TerminalNode SLOW() { return getToken(MariaDBParser.SLOW, 0); }
		public SimpleFlushOptionContext(FlushOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSimpleFlushOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSimpleFlushOption(this);
		}
	}

	public final FlushOptionContext flushOption() throws RecognitionException {
		FlushOptionContext _localctx = new FlushOptionContext(_ctx, getState());
		enterRule(_localctx, 528, RULE_flushOption);
		int _la;
		try {
			setState(6282);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,928,_ctx) ) {
			case 1:
				_localctx = new SimpleFlushOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(6268);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case DES_KEY_FILE:
					{
					setState(6250);
					match(DES_KEY_FILE);
					}
					break;
				case HOSTS:
					{
					setState(6251);
					match(HOSTS);
					}
					break;
				case BINARY:
				case ENGINE:
				case ERROR:
				case GENERAL:
				case LOGS:
				case RELAY:
				case SLOW:
					{
					setState(6253);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==BINARY || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & ((1L << (ENGINE - 409)) | (1L << (ERROR - 409)) | (1L << (GENERAL - 409)))) != 0) || _la==RELAY || _la==SLOW) {
						{
						setState(6252);
						_la = _input.LA(1);
						if ( !(_la==BINARY || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & ((1L << (ENGINE - 409)) | (1L << (ERROR - 409)) | (1L << (GENERAL - 409)))) != 0) || _la==RELAY || _la==SLOW) ) {
						_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
					}

					setState(6255);
					match(LOGS);
					}
					break;
				case OPTIMIZER_COSTS:
					{
					setState(6256);
					match(OPTIMIZER_COSTS);
					}
					break;
				case PRIVILEGES:
					{
					setState(6257);
					match(PRIVILEGES);
					}
					break;
				case QUERY:
					{
					setState(6258);
					match(QUERY);
					setState(6259);
					match(CACHE);
					}
					break;
				case STATUS:
					{
					setState(6260);
					match(STATUS);
					}
					break;
				case USER_RESOURCES:
					{
					setState(6261);
					match(USER_RESOURCES);
					}
					break;
				case TABLES:
					{
					setState(6262);
					match(TABLES);
					setState(6266);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==WITH) {
						{
						setState(6263);
						match(WITH);
						setState(6264);
						match(READ);
						setState(6265);
						match(LOCK);
						}
					}

					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 2:
				_localctx = new ChannelFlushOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6270);
				match(RELAY);
				setState(6271);
				match(LOGS);
				setState(6273);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(6272);
					channelOption();
					}
				}

				}
				break;
			case 3:
				_localctx = new TableFlushOptionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(6275);
				_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(6277);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,926,_ctx) ) {
				case 1:
					{
					setState(6276);
					tables();
					}
					break;
				}
				setState(6280);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR || _la==WITH) {
					{
					setState(6279);
					flushTableOption();
					}
				}

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

	public static class FlushTableOptionContext extends ParserRuleContext {
		public TerminalNode WITH() { return getToken(MariaDBParser.WITH, 0); }
		public TerminalNode READ() { return getToken(MariaDBParser.READ, 0); }
		public TerminalNode LOCK() { return getToken(MariaDBParser.LOCK, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode EXPORT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFlushTableOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFlushTableOption(this);
		}
	}

	public final FlushTableOptionContext flushTableOption() throws RecognitionException {
		FlushTableOptionContext _localctx = new FlushTableOptionContext(_ctx, getState());
		enterRule(_localctx, 530, RULE_flushTableOption);
		try {
			setState(6289);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case WITH:
				enterOuterAlt(_localctx, 1);
				{
				setState(6284);
				match(WITH);
				setState(6285);
				match(READ);
				setState(6286);
				match(LOCK);
				}
				break;
			case FOR:
				enterOuterAlt(_localctx, 2);
				{
				setState(6287);
				match(FOR);
				setState(6288);
				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;
	}

	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(MariaDBParser.PARTITION, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.RR_BRACKET, i);
		}
		public TerminalNode IGNORE() { return getToken(MariaDBParser.IGNORE, 0); }
		public TerminalNode LEAVES() { return getToken(MariaDBParser.LEAVES, 0); }
		public List uidList() {
			return getRuleContexts(UidListContext.class);
		}
		public UidListContext uidList(int i) {
			return getRuleContext(UidListContext.class,i);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public TerminalNode INDEX() { return getToken(MariaDBParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLoadedTableIndexes(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLoadedTableIndexes(this);
		}
	}

	public final LoadedTableIndexesContext loadedTableIndexes() throws RecognitionException {
		LoadedTableIndexesContext _localctx = new LoadedTableIndexesContext(_ctx, getState());
		enterRule(_localctx, 532, RULE_loadedTableIndexes);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6291);
			tableName();
			setState(6299);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(6292);
				match(PARTITION);
				setState(6293);
				match(LR_BRACKET);
				setState(6296);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(6294);
					((LoadedTableIndexesContext)_localctx).partitionList = uidList();
					}
					break;
				case ALL:
					{
					setState(6295);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(6298);
				match(RR_BRACKET);
				}
			}

			setState(6308);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,933,_ctx) ) {
			case 1:
				{
				setState(6302);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INDEX || _la==KEY) {
					{
					setState(6301);
					((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(6304);
				match(LR_BRACKET);
				setState(6305);
				((LoadedTableIndexesContext)_localctx).indexList = uidList();
				setState(6306);
				match(RR_BRACKET);
				}
				break;
			}
			setState(6312);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(6310);
				match(IGNORE);
				setState(6311);
				match(LEAVES);
				}
			}

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

	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(MariaDBParser.EXPLAIN, 0); }
		public TerminalNode DESCRIBE() { return getToken(MariaDBParser.DESCRIBE, 0); }
		public TerminalNode DESC() { return getToken(MariaDBParser.DESC, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSimpleDescribeStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSimpleDescribeStatement(this);
		}
	}

	public final SimpleDescribeStatementContext simpleDescribeStatement() throws RecognitionException {
		SimpleDescribeStatementContext _localctx = new SimpleDescribeStatementContext(_ctx, getState());
		enterRule(_localctx, 534, RULE_simpleDescribeStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6314);
			((SimpleDescribeStatementContext)_localctx).command = _input.LT(1);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << DESC) | (1L << DESCRIBE) | (1L << EXPLAIN))) != 0)) ) {
				((SimpleDescribeStatementContext)_localctx).command = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(6315);
			tableName();
			setState(6318);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,935,_ctx) ) {
			case 1:
				{
				setState(6316);
				((SimpleDescribeStatementContext)_localctx).column = uid();
				}
				break;
			case 2:
				{
				setState(6317);
				((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;
	}

	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(MariaDBParser.EXPLAIN, 0); }
		public TerminalNode DESCRIBE() { return getToken(MariaDBParser.DESCRIBE, 0); }
		public TerminalNode DESC() { return getToken(MariaDBParser.DESC, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode EXTENDED() { return getToken(MariaDBParser.EXTENDED, 0); }
		public TerminalNode PARTITIONS() { return getToken(MariaDBParser.PARTITIONS, 0); }
		public TerminalNode FORMAT() { return getToken(MariaDBParser.FORMAT, 0); }
		public TerminalNode TRADITIONAL() { return getToken(MariaDBParser.TRADITIONAL, 0); }
		public TerminalNode JSON() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFullDescribeStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFullDescribeStatement(this);
		}
	}

	public final FullDescribeStatementContext fullDescribeStatement() throws RecognitionException {
		FullDescribeStatementContext _localctx = new FullDescribeStatementContext(_ctx, getState());
		enterRule(_localctx, 536, RULE_fullDescribeStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6320);
			((FullDescribeStatementContext)_localctx).command = _input.LT(1);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << DESC) | (1L << DESCRIBE) | (1L << EXPLAIN))) != 0)) ) {
				((FullDescribeStatementContext)_localctx).command = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(6324);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EXTENDED || _la==PARTITIONS || _la==FORMAT) {
				{
				setState(6321);
				((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(6322);
				match(EQUAL_SYMBOL);
				setState(6323);
				((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(6326);
			describeObjectClause();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class FormatJsonStatementContext extends ParserRuleContext {
		public Token formatValue;
		public TerminalNode FORMAT() { return getToken(MariaDBParser.FORMAT, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode JSON() { return getToken(MariaDBParser.JSON, 0); }
		public FormatJsonStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_formatJsonStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterFormatJsonStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFormatJsonStatement(this);
		}
	}

	public final FormatJsonStatementContext formatJsonStatement() throws RecognitionException {
		FormatJsonStatementContext _localctx = new FormatJsonStatementContext(_ctx, getState());
		enterRule(_localctx, 538, RULE_formatJsonStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6328);
			match(FORMAT);
			setState(6329);
			match(EQUAL_SYMBOL);
			setState(6330);
			((FormatJsonStatementContext)_localctx).formatValue = match(JSON);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class HelpStatementContext extends ParserRuleContext {
		public TerminalNode HELP() { return getToken(MariaDBParser.HELP, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHelpStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHelpStatement(this);
		}
	}

	public final HelpStatementContext helpStatement() throws RecognitionException {
		HelpStatementContext _localctx = new HelpStatementContext(_ctx, getState());
		enterRule(_localctx, 540, RULE_helpStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6332);
			match(HELP);
			setState(6333);
			match(STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class UseStatementContext extends ParserRuleContext {
		public TerminalNode USE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUseStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUseStatement(this);
		}
	}

	public final UseStatementContext useStatement() throws RecognitionException {
		UseStatementContext _localctx = new UseStatementContext(_ctx, getState());
		enterRule(_localctx, 542, RULE_useStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6335);
			match(USE);
			setState(6336);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class SignalStatementContext extends ParserRuleContext {
		public TerminalNode SIGNAL() { return getToken(MariaDBParser.SIGNAL, 0); }
		public TerminalNode ID() { return getToken(MariaDBParser.ID, 0); }
		public TerminalNode REVERSE_QUOTE_ID() { return getToken(MariaDBParser.REVERSE_QUOTE_ID, 0); }
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public List signalConditionInformation() {
			return getRuleContexts(SignalConditionInformationContext.class);
		}
		public SignalConditionInformationContext signalConditionInformation(int i) {
			return getRuleContext(SignalConditionInformationContext.class,i);
		}
		public TerminalNode SQLSTATE() { return getToken(MariaDBParser.SQLSTATE, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode VALUE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSignalStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSignalStatement(this);
		}
	}

	public final SignalStatementContext signalStatement() throws RecognitionException {
		SignalStatementContext _localctx = new SignalStatementContext(_ctx, getState());
		enterRule(_localctx, 544, RULE_signalStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6338);
			match(SIGNAL);
			setState(6346);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SQLSTATE:
				{
				{
				setState(6339);
				match(SQLSTATE);
				setState(6341);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VALUE) {
					{
					setState(6340);
					match(VALUE);
					}
				}

				setState(6343);
				stringLiteral();
				}
				}
				break;
			case ID:
				{
				setState(6344);
				match(ID);
				}
				break;
			case REVERSE_QUOTE_ID:
				{
				setState(6345);
				match(REVERSE_QUOTE_ID);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(6357);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,940,_ctx) ) {
			case 1:
				{
				setState(6348);
				match(SET);
				setState(6349);
				signalConditionInformation();
				setState(6354);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(6350);
					match(COMMA);
					setState(6351);
					signalConditionInformation();
					}
					}
					setState(6356);
					_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;
	}

	public static class ResignalStatementContext extends ParserRuleContext {
		public TerminalNode RESIGNAL() { return getToken(MariaDBParser.RESIGNAL, 0); }
		public TerminalNode ID() { return getToken(MariaDBParser.ID, 0); }
		public TerminalNode REVERSE_QUOTE_ID() { return getToken(MariaDBParser.REVERSE_QUOTE_ID, 0); }
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public List signalConditionInformation() {
			return getRuleContexts(SignalConditionInformationContext.class);
		}
		public SignalConditionInformationContext signalConditionInformation(int i) {
			return getRuleContext(SignalConditionInformationContext.class,i);
		}
		public TerminalNode SQLSTATE() { return getToken(MariaDBParser.SQLSTATE, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public TerminalNode VALUE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterResignalStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitResignalStatement(this);
		}
	}

	public final ResignalStatementContext resignalStatement() throws RecognitionException {
		ResignalStatementContext _localctx = new ResignalStatementContext(_ctx, getState());
		enterRule(_localctx, 546, RULE_resignalStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6359);
			match(RESIGNAL);
			setState(6367);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SQLSTATE:
				{
				{
				setState(6360);
				match(SQLSTATE);
				setState(6362);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VALUE) {
					{
					setState(6361);
					match(VALUE);
					}
				}

				setState(6364);
				stringLiteral();
				}
				}
				break;
			case ID:
				{
				setState(6365);
				match(ID);
				}
				break;
			case REVERSE_QUOTE_ID:
				{
				setState(6366);
				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 UNLOCK:
			case UPDATE:
			case USE:
			case VALUES:
			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(6378);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,944,_ctx) ) {
			case 1:
				{
				setState(6369);
				match(SET);
				setState(6370);
				signalConditionInformation();
				setState(6375);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(6371);
					match(COMMA);
					setState(6372);
					signalConditionInformation();
					}
					}
					setState(6377);
					_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;
	}

	public static class SignalConditionInformationContext extends ParserRuleContext {
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode CLASS_ORIGIN() { return getToken(MariaDBParser.CLASS_ORIGIN, 0); }
		public TerminalNode SUBCLASS_ORIGIN() { return getToken(MariaDBParser.SUBCLASS_ORIGIN, 0); }
		public TerminalNode MESSAGE_TEXT() { return getToken(MariaDBParser.MESSAGE_TEXT, 0); }
		public TerminalNode MYSQL_ERRNO() { return getToken(MariaDBParser.MYSQL_ERRNO, 0); }
		public TerminalNode CONSTRAINT_CATALOG() { return getToken(MariaDBParser.CONSTRAINT_CATALOG, 0); }
		public TerminalNode CONSTRAINT_SCHEMA() { return getToken(MariaDBParser.CONSTRAINT_SCHEMA, 0); }
		public TerminalNode CONSTRAINT_NAME() { return getToken(MariaDBParser.CONSTRAINT_NAME, 0); }
		public TerminalNode CATALOG_NAME() { return getToken(MariaDBParser.CATALOG_NAME, 0); }
		public TerminalNode SCHEMA_NAME() { return getToken(MariaDBParser.SCHEMA_NAME, 0); }
		public TerminalNode TABLE_NAME() { return getToken(MariaDBParser.TABLE_NAME, 0); }
		public TerminalNode COLUMN_NAME() { return getToken(MariaDBParser.COLUMN_NAME, 0); }
		public TerminalNode CURSOR_NAME() { return getToken(MariaDBParser.CURSOR_NAME, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public TerminalNode DECIMAL_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSignalConditionInformation(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSignalConditionInformation(this);
		}
	}

	public final SignalConditionInformationContext signalConditionInformation() throws RecognitionException {
		SignalConditionInformationContext _localctx = new SignalConditionInformationContext(_ctx, getState());
		enterRule(_localctx, 548, RULE_signalConditionInformation);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6380);
			_la = _input.LA(1);
			if ( !(((((_la - 359)) & ~0x3f) == 0 && ((1L << (_la - 359)) & ((1L << (CLASS_ORIGIN - 359)) | (1L << (COLUMN_NAME - 359)) | (1L << (CONSTRAINT_CATALOG - 359)) | (1L << (CONSTRAINT_SCHEMA - 359)) | (1L << (CONSTRAINT_NAME - 359)) | (1L << (CURSOR_NAME - 359)))) != 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(6381);
			match(EQUAL_SYMBOL);
			setState(6386);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case START_NATIONAL_STRING_LITERAL:
			case STRING_LITERAL:
			case STRING_CHARSET_NAME:
				{
				setState(6382);
				stringLiteral();
				}
				break;
			case DECIMAL_LITERAL:
				{
				setState(6383);
				match(DECIMAL_LITERAL);
				}
				break;
			case LOCAL_ID:
			case GLOBAL_ID:
				{
				setState(6384);
				mysqlVariable();
				}
				break;
			case ATTRIBUTE:
			case BODY:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_ROLE:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case LOCKED:
			case MAXVALUE:
			case MINVALUE:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case PACKAGE:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_:
			case STACKED:
			case STATEMENT:
			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 CYCLE:
			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 ENCRYPTED:
			case ENCRYPTION:
			case ENCRYPTION_KEY_ID:
			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 INCREMENT:
			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 LOCALES:
			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 NOCACHE:
			case NOCOPY:
			case NOCYCLE:
			case NOMAXVALUE:
			case NOMINVALUE:
			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 QUERY_RESPONSE_TIME:
			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 RESTART:
			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 SEQUENCE:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLAVES:
			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 TYPES:
			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 WSREP_MEMBERSHIP:
			case WSREP_STATUS:
			case X509:
			case XA:
			case XML:
			case YES:
			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 USER_STATISTICS:
			case CLIENT_STATISTICS:
			case INDEX_STATISTICS:
			case TABLE_STATISTICS:
			case ADMIN:
			case AUDIT_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_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_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 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 VIA:
			case LASTVAL:
			case NEXTVAL:
			case SETVAL:
			case PREVIOUS:
			case PERSISTENT:
			case BINLOG_MONITOR:
			case BINLOG_REPLAY:
			case FEDERATED_ADMIN:
			case READ_ONLY_ADMIN:
			case REPLICA:
			case REPLICAS:
			case REPLICATION_MASTER_ADMIN:
			case MONITOR:
			case READ_ONLY:
			case REPLAY:
			case MOD:
			case ID:
				{
				setState(6385);
				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;
	}

	public static class DiagnosticsStatementContext extends ParserRuleContext {
		public TerminalNode GET() { return getToken(MariaDBParser.GET, 0); }
		public TerminalNode DIAGNOSTICS() { return getToken(MariaDBParser.DIAGNOSTICS, 0); }
		public TerminalNode CURRENT() { return getToken(MariaDBParser.CURRENT, 0); }
		public TerminalNode STACKED() { return getToken(MariaDBParser.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(MariaDBParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MariaDBParser.EQUAL_SYMBOL, i);
		}
		public TerminalNode CONDITION() { return getToken(MariaDBParser.CONDITION, 0); }
		public List diagnosticsConditionInformationName() {
			return getRuleContexts(DiagnosticsConditionInformationNameContext.class);
		}
		public DiagnosticsConditionInformationNameContext diagnosticsConditionInformationName(int i) {
			return getRuleContext(DiagnosticsConditionInformationNameContext.class,i);
		}
		public List NUMBER() { return getTokens(MariaDBParser.NUMBER); }
		public TerminalNode NUMBER(int i) {
			return getToken(MariaDBParser.NUMBER, i);
		}
		public List ROW_COUNT() { return getTokens(MariaDBParser.ROW_COUNT); }
		public TerminalNode ROW_COUNT(int i) {
			return getToken(MariaDBParser.ROW_COUNT, i);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDiagnosticsStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDiagnosticsStatement(this);
		}
	}

	public final DiagnosticsStatementContext diagnosticsStatement() throws RecognitionException {
		DiagnosticsStatementContext _localctx = new DiagnosticsStatementContext(_ctx, getState());
		enterRule(_localctx, 550, RULE_diagnosticsStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6388);
			match(GET);
			setState(6390);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CURRENT || _la==STACKED) {
				{
				setState(6389);
				_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(6392);
			match(DIAGNOSTICS);
			setState(6424);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,950,_ctx) ) {
			case 1:
				{
				{
				setState(6393);
				variableClause();
				setState(6394);
				match(EQUAL_SYMBOL);
				setState(6395);
				_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(6403);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(6396);
					match(COMMA);
					setState(6397);
					variableClause();
					setState(6398);
					match(EQUAL_SYMBOL);
					setState(6399);
					_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(6405);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				}
				break;
			case 2:
				{
				{
				setState(6406);
				match(CONDITION);
				setState(6409);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ZERO_DECIMAL:
				case ONE_DECIMAL:
				case TWO_DECIMAL:
				case DECIMAL_LITERAL:
				case REAL_LITERAL:
					{
					setState(6407);
					decimalLiteral();
					}
					break;
				case ATTRIBUTE:
				case BODY:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_ROLE:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case LOCKED:
				case MAXVALUE:
				case MINVALUE:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case PACKAGE:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_:
				case STACKED:
				case STATEMENT:
				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 CYCLE:
				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 ENCRYPTED:
				case ENCRYPTION:
				case ENCRYPTION_KEY_ID:
				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 INCREMENT:
				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 LOCALES:
				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 NOCACHE:
				case NOCOPY:
				case NOCYCLE:
				case NOMAXVALUE:
				case NOMINVALUE:
				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 QUERY_RESPONSE_TIME:
				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 RESTART:
				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 SEQUENCE:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLAVES:
				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 TYPES:
				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 WSREP_MEMBERSHIP:
				case WSREP_STATUS:
				case X509:
				case XA:
				case XML:
				case YES:
				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 USER_STATISTICS:
				case CLIENT_STATISTICS:
				case INDEX_STATISTICS:
				case TABLE_STATISTICS:
				case ADMIN:
				case AUDIT_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_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_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 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 VIA:
				case LASTVAL:
				case NEXTVAL:
				case SETVAL:
				case PREVIOUS:
				case PERSISTENT:
				case BINLOG_MONITOR:
				case BINLOG_REPLAY:
				case FEDERATED_ADMIN:
				case READ_ONLY_ADMIN:
				case REPLICA:
				case REPLICAS:
				case REPLICATION_MASTER_ADMIN:
				case MONITOR:
				case READ_ONLY:
				case REPLAY:
				case MOD:
				case AT_SIGN:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
				case LOCAL_ID:
				case GLOBAL_ID:
					{
					setState(6408);
					variableClause();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(6411);
				variableClause();
				setState(6412);
				match(EQUAL_SYMBOL);
				setState(6413);
				diagnosticsConditionInformationName();
				setState(6421);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(6414);
					match(COMMA);
					setState(6415);
					variableClause();
					setState(6416);
					match(EQUAL_SYMBOL);
					setState(6417);
					diagnosticsConditionInformationName();
					}
					}
					setState(6423);
					_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;
	}

	public static class DiagnosticsConditionInformationNameContext extends ParserRuleContext {
		public TerminalNode CLASS_ORIGIN() { return getToken(MariaDBParser.CLASS_ORIGIN, 0); }
		public TerminalNode SUBCLASS_ORIGIN() { return getToken(MariaDBParser.SUBCLASS_ORIGIN, 0); }
		public TerminalNode RETURNED_SQLSTATE() { return getToken(MariaDBParser.RETURNED_SQLSTATE, 0); }
		public TerminalNode MESSAGE_TEXT() { return getToken(MariaDBParser.MESSAGE_TEXT, 0); }
		public TerminalNode MYSQL_ERRNO() { return getToken(MariaDBParser.MYSQL_ERRNO, 0); }
		public TerminalNode CONSTRAINT_CATALOG() { return getToken(MariaDBParser.CONSTRAINT_CATALOG, 0); }
		public TerminalNode CONSTRAINT_SCHEMA() { return getToken(MariaDBParser.CONSTRAINT_SCHEMA, 0); }
		public TerminalNode CONSTRAINT_NAME() { return getToken(MariaDBParser.CONSTRAINT_NAME, 0); }
		public TerminalNode CATALOG_NAME() { return getToken(MariaDBParser.CATALOG_NAME, 0); }
		public TerminalNode SCHEMA_NAME() { return getToken(MariaDBParser.SCHEMA_NAME, 0); }
		public TerminalNode TABLE_NAME() { return getToken(MariaDBParser.TABLE_NAME, 0); }
		public TerminalNode COLUMN_NAME() { return getToken(MariaDBParser.COLUMN_NAME, 0); }
		public TerminalNode CURSOR_NAME() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDiagnosticsConditionInformationName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDiagnosticsConditionInformationName(this);
		}
	}

	public final DiagnosticsConditionInformationNameContext diagnosticsConditionInformationName() throws RecognitionException {
		DiagnosticsConditionInformationNameContext _localctx = new DiagnosticsConditionInformationNameContext(_ctx, getState());
		enterRule(_localctx, 552, RULE_diagnosticsConditionInformationName);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6426);
			_la = _input.LA(1);
			if ( !(((((_la - 359)) & ~0x3f) == 0 && ((1L << (_la - 359)) & ((1L << (CLASS_ORIGIN - 359)) | (1L << (COLUMN_NAME - 359)) | (1L << (CONSTRAINT_CATALOG - 359)) | (1L << (CONSTRAINT_SCHEMA - 359)) | (1L << (CONSTRAINT_NAME - 359)) | (1L << (CURSOR_NAME - 359)))) != 0) || _la==MESSAGE_TEXT || _la==MYSQL_ERRNO || ((((_la - 594)) & ~0x3f) == 0 && ((1L << (_la - 594)) & ((1L << (RETURNED_SQLSTATE - 594)) | (1L << (SUBCLASS_ORIGIN - 594)) | (1L << (TABLE_NAME - 594)))) != 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;
	}

	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);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDescribeStatements(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDescribeStatements(this);
		}
	}
	public static class DescribeConnectionContext extends DescribeObjectClauseContext {
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode CONNECTION() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDescribeConnection(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDescribeConnection(this);
		}
	}

	public final DescribeObjectClauseContext describeObjectClause() throws RecognitionException {
		DescribeObjectClauseContext _localctx = new DescribeObjectClauseContext(_ctx, getState());
		enterRule(_localctx, 554, RULE_describeObjectClause);
		try {
			setState(6438);
			_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(6433);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case SELECT:
				case LR_BRACKET:
					{
					setState(6428);
					selectStatement();
					}
					break;
				case DELETE:
					{
					setState(6429);
					deleteStatement();
					}
					break;
				case INSERT:
					{
					setState(6430);
					insertStatement();
					}
					break;
				case REPLACE:
					{
					setState(6431);
					replaceStatement();
					}
					break;
				case UPDATE:
					{
					setState(6432);
					updateStatement();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case FOR:
				_localctx = new DescribeConnectionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6435);
				match(FOR);
				setState(6436);
				match(CONNECTION);
				setState(6437);
				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;
	}

	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(MariaDBParser.DOT_ID, 0); }
		public TerminalNode DOT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFullId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFullId(this);
		}
	}

	public final FullIdContext fullId() throws RecognitionException {
		FullIdContext _localctx = new FullIdContext(_ctx, getState());
		enterRule(_localctx, 556, RULE_fullId);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6440);
			uid();
			setState(6444);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,953,_ctx) ) {
			case 1:
				{
				setState(6441);
				match(DOT_ID);
				}
				break;
			case 2:
				{
				setState(6442);
				match(DOT);
				setState(6443);
				uid();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTableName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTableName(this);
		}
	}

	public final TableNameContext tableName() throws RecognitionException {
		TableNameContext _localctx = new TableNameContext(_ctx, getState());
		enterRule(_localctx, 558, RULE_tableName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6446);
			fullId();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterRoleName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRoleName(this);
		}
	}

	public final RoleNameContext roleName() throws RecognitionException {
		RoleNameContext _localctx = new RoleNameContext(_ctx, getState());
		enterRule(_localctx, 560, RULE_roleName);
		try {
			setState(6450);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,954,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6448);
				userName();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6449);
				uid();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFullColumnName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFullColumnName(this);
		}
	}

	public final FullColumnNameContext fullColumnName() throws RecognitionException {
		FullColumnNameContext _localctx = new FullColumnNameContext(_ctx, getState());
		enterRule(_localctx, 562, RULE_fullColumnName);
		try {
			setState(6464);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,958,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6452);
				uid();
				setState(6457);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,956,_ctx) ) {
				case 1:
					{
					setState(6453);
					dottedId();
					setState(6455);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,955,_ctx) ) {
					case 1:
						{
						setState(6454);
						dottedId();
						}
						break;
					}
					}
					break;
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6459);
				matchWildcard();
				setState(6460);
				dottedId();
				setState(6462);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,957,_ctx) ) {
				case 1:
					{
					setState(6461);
					dottedId();
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode ASC() { return getToken(MariaDBParser.ASC, 0); }
		public TerminalNode DESC() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIndexColumnName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIndexColumnName(this);
		}
	}

	public final IndexColumnNameContext indexColumnName() throws RecognitionException {
		IndexColumnNameContext _localctx = new IndexColumnNameContext(_ctx, getState());
		enterRule(_localctx, 564, RULE_indexColumnName);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6477);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,961,_ctx) ) {
			case 1:
				{
				setState(6468);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,959,_ctx) ) {
				case 1:
					{
					setState(6466);
					uid();
					}
					break;
				case 2:
					{
					setState(6467);
					match(STRING_LITERAL);
					}
					break;
				}
				setState(6474);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(6470);
					match(LR_BRACKET);
					setState(6471);
					decimalLiteral();
					setState(6472);
					match(RR_BRACKET);
					}
				}

				}
				break;
			case 2:
				{
				setState(6476);
				expression(0);
				}
				break;
			}
			setState(6480);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ASC || _la==DESC) {
				{
				setState(6479);
				((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;
	}

	public static class SimpleUserNameContext extends ParserRuleContext {
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode ID() { return getToken(MariaDBParser.ID, 0); }
		public TerminalNode ADMIN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSimpleUserName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSimpleUserName(this);
		}
	}

	public final SimpleUserNameContext simpleUserName() throws RecognitionException {
		SimpleUserNameContext _localctx = new SimpleUserNameContext(_ctx, getState());
		enterRule(_localctx, 566, RULE_simpleUserName);
		try {
			setState(6486);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,963,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6482);
				match(STRING_LITERAL);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6483);
				match(ID);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6484);
				match(ADMIN);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(6485);
				keywordsCanBeId();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class HostNameContext extends ParserRuleContext {
		public TerminalNode LOCAL_ID() { return getToken(MariaDBParser.LOCAL_ID, 0); }
		public TerminalNode HOST_IP_ADDRESS() { return getToken(MariaDBParser.HOST_IP_ADDRESS, 0); }
		public TerminalNode AT_SIGN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHostName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHostName(this);
		}
	}

	public final HostNameContext hostName() throws RecognitionException {
		HostNameContext _localctx = new HostNameContext(_ctx, getState());
		enterRule(_localctx, 568, RULE_hostName);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6488);
			_la = _input.LA(1);
			if ( !(((((_la - 1158)) & ~0x3f) == 0 && ((1L << (_la - 1158)) & ((1L << (AT_SIGN - 1158)) | (1L << (HOST_IP_ADDRESS - 1158)) | (1L << (LOCAL_ID - 1158)))) != 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;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUserName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUserName(this);
		}
	}

	public final UserNameContext userName() throws RecognitionException {
		UserNameContext _localctx = new UserNameContext(_ctx, getState());
		enterRule(_localctx, 570, RULE_userName);
		try {
			setState(6495);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,964,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6490);
				simpleUserName();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6491);
				simpleUserName();
				setState(6492);
				hostName();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6494);
				currentUserExpression();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class MysqlVariableContext extends ParserRuleContext {
		public TerminalNode LOCAL_ID() { return getToken(MariaDBParser.LOCAL_ID, 0); }
		public TerminalNode GLOBAL_ID() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterMysqlVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMysqlVariable(this);
		}
	}

	public final MysqlVariableContext mysqlVariable() throws RecognitionException {
		MysqlVariableContext _localctx = new MysqlVariableContext(_ctx, getState());
		enterRule(_localctx, 572, RULE_mysqlVariable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6497);
			_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;
	}

	public static class CharsetNameContext extends ParserRuleContext {
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public CharsetNameBaseContext charsetNameBase() {
			return getRuleContext(CharsetNameBaseContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode CHARSET_REVERSE_QOUTE_STRING() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCharsetName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCharsetName(this);
		}
	}

	public final CharsetNameContext charsetName() throws RecognitionException {
		CharsetNameContext _localctx = new CharsetNameContext(_ctx, getState());
		enterRule(_localctx, 574, RULE_charsetName);
		try {
			setState(6503);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,965,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6499);
				match(BINARY);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6500);
				charsetNameBase();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6501);
				match(STRING_LITERAL);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(6502);
				match(CHARSET_REVERSE_QOUTE_STRING);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CollationNameContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCollationName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCollationName(this);
		}
	}

	public final CollationNameContext collationName() throws RecognitionException {
		CollationNameContext _localctx = new CollationNameContext(_ctx, getState());
		enterRule(_localctx, 576, RULE_collationName);
		try {
			setState(6507);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,966,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6505);
				uid();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6506);
				match(STRING_LITERAL);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class EngineNameContext extends ParserRuleContext {
		public EngineNameBaseContext engineNameBase() {
			return getRuleContext(EngineNameBaseContext.class,0);
		}
		public TerminalNode ID() { return getToken(MariaDBParser.ID, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterEngineName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitEngineName(this);
		}
	}

	public final EngineNameContext engineName() throws RecognitionException {
		EngineNameContext _localctx = new EngineNameContext(_ctx, getState());
		enterRule(_localctx, 578, RULE_engineName);
		try {
			setState(6512);
			_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(6509);
				engineNameBase();
				}
				break;
			case ID:
				enterOuterAlt(_localctx, 2);
				{
				setState(6510);
				match(ID);
				}
				break;
			case STRING_LITERAL:
				enterOuterAlt(_localctx, 3);
				{
				setState(6511);
				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;
	}

	public static class EngineNameBaseContext extends ParserRuleContext {
		public TerminalNode ARCHIVE() { return getToken(MariaDBParser.ARCHIVE, 0); }
		public TerminalNode BLACKHOLE() { return getToken(MariaDBParser.BLACKHOLE, 0); }
		public TerminalNode CONNECT() { return getToken(MariaDBParser.CONNECT, 0); }
		public TerminalNode CSV() { return getToken(MariaDBParser.CSV, 0); }
		public TerminalNode FEDERATED() { return getToken(MariaDBParser.FEDERATED, 0); }
		public TerminalNode INNODB() { return getToken(MariaDBParser.INNODB, 0); }
		public TerminalNode MEMORY() { return getToken(MariaDBParser.MEMORY, 0); }
		public TerminalNode MRG_MYISAM() { return getToken(MariaDBParser.MRG_MYISAM, 0); }
		public TerminalNode MYISAM() { return getToken(MariaDBParser.MYISAM, 0); }
		public TerminalNode NDB() { return getToken(MariaDBParser.NDB, 0); }
		public TerminalNode NDBCLUSTER() { return getToken(MariaDBParser.NDBCLUSTER, 0); }
		public TerminalNode PERFORMANCE_SCHEMA() { return getToken(MariaDBParser.PERFORMANCE_SCHEMA, 0); }
		public TerminalNode TOKUDB() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterEngineNameBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitEngineNameBase(this);
		}
	}

	public final EngineNameBaseContext engineNameBase() throws RecognitionException {
		EngineNameBaseContext _localctx = new EngineNameBaseContext(_ctx, getState());
		enterRule(_localctx, 580, RULE_engineNameBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6514);
			_la = _input.LA(1);
			if ( !(_la==CONNECT || ((((_la - 794)) & ~0x3f) == 0 && ((1L << (_la - 794)) & ((1L << (ARCHIVE - 794)) | (1L << (BLACKHOLE - 794)) | (1L << (CSV - 794)) | (1L << (FEDERATED - 794)) | (1L << (INNODB - 794)) | (1L << (MEMORY - 794)) | (1L << (MRG_MYISAM - 794)) | (1L << (MYISAM - 794)) | (1L << (NDB - 794)) | (1L << (NDBCLUSTER - 794)) | (1L << (PERFORMANCE_SCHEMA - 794)) | (1L << (TOKUDB - 794)))) != 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;
	}

	public static class EncryptedLiteralContext extends ParserRuleContext {
		public TerminalNode ENCRYPTED() { return getToken(MariaDBParser.ENCRYPTED, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public EncryptedLiteralContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_encryptedLiteral; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterEncryptedLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitEncryptedLiteral(this);
		}
	}

	public final EncryptedLiteralContext encryptedLiteral() throws RecognitionException {
		EncryptedLiteralContext _localctx = new EncryptedLiteralContext(_ctx, getState());
		enterRule(_localctx, 582, RULE_encryptedLiteral);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6516);
			_la = _input.LA(1);
			if ( !(_la==ENCRYPTED || _la==STRING_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;
	}

	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(MariaDBParser.MINUS); }
		public TerminalNode MINUS(int i) {
			return getToken(MariaDBParser.MINUS, i);
		}
		public List COLON_SYMB() { return getTokens(MariaDBParser.COLON_SYMB); }
		public TerminalNode COLON_SYMB(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUuidSet(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUuidSet(this);
		}
	}

	public final UuidSetContext uuidSet() throws RecognitionException {
		UuidSetContext _localctx = new UuidSetContext(_ctx, getState());
		enterRule(_localctx, 584, RULE_uuidSet);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6518);
			decimalLiteral();
			setState(6519);
			match(MINUS);
			setState(6520);
			decimalLiteral();
			setState(6521);
			match(MINUS);
			setState(6522);
			decimalLiteral();
			setState(6523);
			match(MINUS);
			setState(6524);
			decimalLiteral();
			setState(6525);
			match(MINUS);
			setState(6526);
			decimalLiteral();
			setState(6532); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(6527);
				match(COLON_SYMB);
				setState(6528);
				decimalLiteral();
				setState(6529);
				match(MINUS);
				setState(6530);
				decimalLiteral();
				}
				}
				setState(6534); 
				_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;
	}

	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterXid(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitXid(this);
		}
	}

	public final XidContext xid() throws RecognitionException {
		XidContext _localctx = new XidContext(_ctx, getState());
		enterRule(_localctx, 586, RULE_xid);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6536);
			((XidContext)_localctx).globalTableUid = xuidStringId();
			setState(6543);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMA) {
				{
				setState(6537);
				match(COMMA);
				setState(6538);
				((XidContext)_localctx).qualifier = xuidStringId();
				setState(6541);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(6539);
					match(COMMA);
					setState(6540);
					((XidContext)_localctx).idFormat = decimalLiteral();
					}
				}

				}
			}

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

	public static class XuidStringIdContext extends ParserRuleContext {
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public TerminalNode BIT_STRING() { return getToken(MariaDBParser.BIT_STRING, 0); }
		public List HEXADECIMAL_LITERAL() { return getTokens(MariaDBParser.HEXADECIMAL_LITERAL); }
		public TerminalNode HEXADECIMAL_LITERAL(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterXuidStringId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitXuidStringId(this);
		}
	}

	public final XuidStringIdContext xuidStringId() throws RecognitionException {
		XuidStringIdContext _localctx = new XuidStringIdContext(_ctx, getState());
		enterRule(_localctx, 588, RULE_xuidStringId);
		int _la;
		try {
			setState(6552);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case STRING_LITERAL:
				enterOuterAlt(_localctx, 1);
				{
				setState(6545);
				match(STRING_LITERAL);
				}
				break;
			case BIT_STRING:
				enterOuterAlt(_localctx, 2);
				{
				setState(6546);
				match(BIT_STRING);
				}
				break;
			case HEXADECIMAL_LITERAL:
				enterOuterAlt(_localctx, 3);
				{
				setState(6548); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(6547);
					match(HEXADECIMAL_LITERAL);
					}
					}
					setState(6550); 
					_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;
	}

	public static class AuthPluginContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAuthPlugin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAuthPlugin(this);
		}
	}

	public final AuthPluginContext authPlugin() throws RecognitionException {
		AuthPluginContext _localctx = new AuthPluginContext(_ctx, getState());
		enterRule(_localctx, 590, RULE_authPlugin);
		try {
			setState(6556);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,973,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6554);
				uid();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6555);
				match(STRING_LITERAL);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class UidContext extends ParserRuleContext {
		public SimpleIdContext simpleId() {
			return getRuleContext(SimpleIdContext.class,0);
		}
		public TerminalNode CHARSET_REVERSE_QOUTE_STRING() { return getToken(MariaDBParser.CHARSET_REVERSE_QOUTE_STRING, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUid(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUid(this);
		}
	}

	public final UidContext uid() throws RecognitionException {
		UidContext _localctx = new UidContext(_ctx, getState());
		enterRule(_localctx, 592, RULE_uid);
		try {
			setState(6561);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ATTRIBUTE:
			case BODY:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_ROLE:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case LOCKED:
			case MAXVALUE:
			case MINVALUE:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case PACKAGE:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_:
			case STACKED:
			case STATEMENT:
			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 CYCLE:
			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 ENCRYPTED:
			case ENCRYPTION:
			case ENCRYPTION_KEY_ID:
			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 INCREMENT:
			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 LOCALES:
			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 NOCACHE:
			case NOCOPY:
			case NOCYCLE:
			case NOMAXVALUE:
			case NOMINVALUE:
			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 QUERY_RESPONSE_TIME:
			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 RESTART:
			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 SEQUENCE:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLAVES:
			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 TYPES:
			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 WSREP_MEMBERSHIP:
			case WSREP_STATUS:
			case X509:
			case XA:
			case XML:
			case YES:
			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 USER_STATISTICS:
			case CLIENT_STATISTICS:
			case INDEX_STATISTICS:
			case TABLE_STATISTICS:
			case ADMIN:
			case AUDIT_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_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_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 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 VIA:
			case LASTVAL:
			case NEXTVAL:
			case SETVAL:
			case PREVIOUS:
			case PERSISTENT:
			case BINLOG_MONITOR:
			case BINLOG_REPLAY:
			case FEDERATED_ADMIN:
			case READ_ONLY_ADMIN:
			case REPLICA:
			case REPLICAS:
			case REPLICATION_MASTER_ADMIN:
			case MONITOR:
			case READ_ONLY:
			case REPLAY:
			case MOD:
			case ID:
				enterOuterAlt(_localctx, 1);
				{
				setState(6558);
				simpleId();
				}
				break;
			case CHARSET_REVERSE_QOUTE_STRING:
				enterOuterAlt(_localctx, 2);
				{
				setState(6559);
				match(CHARSET_REVERSE_QOUTE_STRING);
				}
				break;
			case STRING_LITERAL:
				enterOuterAlt(_localctx, 3);
				{
				setState(6560);
				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;
	}

	public static class SimpleIdContext extends ParserRuleContext {
		public TerminalNode ID() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSimpleId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSimpleId(this);
		}
	}

	public final SimpleIdContext simpleId() throws RecognitionException {
		SimpleIdContext _localctx = new SimpleIdContext(_ctx, getState());
		enterRule(_localctx, 594, RULE_simpleId);
		try {
			setState(6572);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,975,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6563);
				match(ID);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6564);
				charsetNameBase();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6565);
				transactionLevelBase();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(6566);
				engineNameBase();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(6567);
				privilegesBase();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(6568);
				intervalTypeBase();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(6569);
				dataTypeBase();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(6570);
				keywordsCanBeId();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(6571);
				scalarFunctionName();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class DottedIdContext extends ParserRuleContext {
		public TerminalNode DOT_ID() { return getToken(MariaDBParser.DOT_ID, 0); }
		public TerminalNode DOT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDottedId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDottedId(this);
		}
	}

	public final DottedIdContext dottedId() throws RecognitionException {
		DottedIdContext _localctx = new DottedIdContext(_ctx, getState());
		enterRule(_localctx, 596, RULE_dottedId);
		try {
			setState(6577);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DOT_ID:
				enterOuterAlt(_localctx, 1);
				{
				setState(6574);
				match(DOT_ID);
				}
				break;
			case DOT:
				enterOuterAlt(_localctx, 2);
				{
				setState(6575);
				match(DOT);
				setState(6576);
				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;
	}

	public static class DecimalLiteralContext extends ParserRuleContext {
		public TerminalNode DECIMAL_LITERAL() { return getToken(MariaDBParser.DECIMAL_LITERAL, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MariaDBParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MariaDBParser.ONE_DECIMAL, 0); }
		public TerminalNode TWO_DECIMAL() { return getToken(MariaDBParser.TWO_DECIMAL, 0); }
		public TerminalNode REAL_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDecimalLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDecimalLiteral(this);
		}
	}

	public final DecimalLiteralContext decimalLiteral() throws RecognitionException {
		DecimalLiteralContext _localctx = new DecimalLiteralContext(_ctx, getState());
		enterRule(_localctx, 598, RULE_decimalLiteral);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6579);
			_la = _input.LA(1);
			if ( !(((((_la - 1159)) & ~0x3f) == 0 && ((1L << (_la - 1159)) & ((1L << (ZERO_DECIMAL - 1159)) | (1L << (ONE_DECIMAL - 1159)) | (1L << (TWO_DECIMAL - 1159)) | (1L << (DECIMAL_LITERAL - 1159)) | (1L << (REAL_LITERAL - 1159)))) != 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;
	}

	public static class FileSizeLiteralContext extends ParserRuleContext {
		public TerminalNode FILESIZE_LITERAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFileSizeLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFileSizeLiteral(this);
		}
	}

	public final FileSizeLiteralContext fileSizeLiteral() throws RecognitionException {
		FileSizeLiteralContext _localctx = new FileSizeLiteralContext(_ctx, getState());
		enterRule(_localctx, 600, RULE_fileSizeLiteral);
		try {
			setState(6583);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case FILESIZE_LITERAL:
				enterOuterAlt(_localctx, 1);
				{
				setState(6581);
				match(FILESIZE_LITERAL);
				}
				break;
			case ZERO_DECIMAL:
			case ONE_DECIMAL:
			case TWO_DECIMAL:
			case DECIMAL_LITERAL:
			case REAL_LITERAL:
				enterOuterAlt(_localctx, 2);
				{
				setState(6582);
				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;
	}

	public static class StringLiteralContext extends ParserRuleContext {
		public List STRING_LITERAL() { return getTokens(MariaDBParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MariaDBParser.STRING_LITERAL, i);
		}
		public TerminalNode START_NATIONAL_STRING_LITERAL() { return getToken(MariaDBParser.START_NATIONAL_STRING_LITERAL, 0); }
		public TerminalNode STRING_CHARSET_NAME() { return getToken(MariaDBParser.STRING_CHARSET_NAME, 0); }
		public TerminalNode COLLATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterStringLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStringLiteral(this);
		}
	}

	public final StringLiteralContext stringLiteral() throws RecognitionException {
		StringLiteralContext _localctx = new StringLiteralContext(_ctx, getState());
		enterRule(_localctx, 602, RULE_stringLiteral);
		int _la;
		try {
			int _alt;
			setState(6608);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,984,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6590);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case STRING_LITERAL:
				case STRING_CHARSET_NAME:
					{
					setState(6586);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==STRING_CHARSET_NAME) {
						{
						setState(6585);
						match(STRING_CHARSET_NAME);
						}
					}

					setState(6588);
					match(STRING_LITERAL);
					}
					break;
				case START_NATIONAL_STRING_LITERAL:
					{
					setState(6589);
					match(START_NATIONAL_STRING_LITERAL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(6593); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(6592);
						match(STRING_LITERAL);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(6595); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,980,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6602);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case STRING_LITERAL:
				case STRING_CHARSET_NAME:
					{
					setState(6598);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==STRING_CHARSET_NAME) {
						{
						setState(6597);
						match(STRING_CHARSET_NAME);
						}
					}

					setState(6600);
					match(STRING_LITERAL);
					}
					break;
				case START_NATIONAL_STRING_LITERAL:
					{
					setState(6601);
					match(START_NATIONAL_STRING_LITERAL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(6606);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,983,_ctx) ) {
				case 1:
					{
					setState(6604);
					match(COLLATE);
					setState(6605);
					collationName();
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class BooleanLiteralContext extends ParserRuleContext {
		public TerminalNode TRUE() { return getToken(MariaDBParser.TRUE, 0); }
		public TerminalNode FALSE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterBooleanLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitBooleanLiteral(this);
		}
	}

	public final BooleanLiteralContext booleanLiteral() throws RecognitionException {
		BooleanLiteralContext _localctx = new BooleanLiteralContext(_ctx, getState());
		enterRule(_localctx, 604, RULE_booleanLiteral);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6610);
			_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;
	}

	public static class HexadecimalLiteralContext extends ParserRuleContext {
		public TerminalNode HEXADECIMAL_LITERAL() { return getToken(MariaDBParser.HEXADECIMAL_LITERAL, 0); }
		public TerminalNode STRING_CHARSET_NAME() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterHexadecimalLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitHexadecimalLiteral(this);
		}
	}

	public final HexadecimalLiteralContext hexadecimalLiteral() throws RecognitionException {
		HexadecimalLiteralContext _localctx = new HexadecimalLiteralContext(_ctx, getState());
		enterRule(_localctx, 606, RULE_hexadecimalLiteral);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6613);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==STRING_CHARSET_NAME) {
				{
				setState(6612);
				match(STRING_CHARSET_NAME);
				}
			}

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

	public static class NullNotnullContext extends ParserRuleContext {
		public TerminalNode NULL_LITERAL() { return getToken(MariaDBParser.NULL_LITERAL, 0); }
		public TerminalNode NULL_SPEC_LITERAL() { return getToken(MariaDBParser.NULL_SPEC_LITERAL, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterNullNotnull(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitNullNotnull(this);
		}
	}

	public final NullNotnullContext nullNotnull() throws RecognitionException {
		NullNotnullContext _localctx = new NullNotnullContext(_ctx, getState());
		enterRule(_localctx, 608, RULE_nullNotnull);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6618);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOT) {
				{
				setState(6617);
				match(NOT);
				}
			}

			setState(6620);
			_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;
	}

	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(MariaDBParser.MINUS, 0); }
		public HexadecimalLiteralContext hexadecimalLiteral() {
			return getRuleContext(HexadecimalLiteralContext.class,0);
		}
		public BooleanLiteralContext booleanLiteral() {
			return getRuleContext(BooleanLiteralContext.class,0);
		}
		public TerminalNode REAL_LITERAL() { return getToken(MariaDBParser.REAL_LITERAL, 0); }
		public TerminalNode BIT_STRING() { return getToken(MariaDBParser.BIT_STRING, 0); }
		public TerminalNode NULL_LITERAL() { return getToken(MariaDBParser.NULL_LITERAL, 0); }
		public TerminalNode NULL_SPEC_LITERAL() { return getToken(MariaDBParser.NULL_SPEC_LITERAL, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterConstant(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitConstant(this);
		}
	}

	public final ConstantContext constant() throws RecognitionException {
		ConstantContext _localctx = new ConstantContext(_ctx, getState());
		enterRule(_localctx, 610, RULE_constant);
		int _la;
		try {
			setState(6634);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,988,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6622);
				stringLiteral();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6623);
				decimalLiteral();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6624);
				match(MINUS);
				setState(6625);
				decimalLiteral();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(6626);
				hexadecimalLiteral();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(6627);
				booleanLiteral();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(6628);
				match(REAL_LITERAL);
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(6629);
				match(BIT_STRING);
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(6631);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(6630);
					match(NOT);
					}
				}

				setState(6633);
				((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;
	}

	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);
		}
	}
	public static class SpatialDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode GEOMETRYCOLLECTION() { return getToken(MariaDBParser.GEOMETRYCOLLECTION, 0); }
		public TerminalNode GEOMCOLLECTION() { return getToken(MariaDBParser.GEOMCOLLECTION, 0); }
		public TerminalNode LINESTRING() { return getToken(MariaDBParser.LINESTRING, 0); }
		public TerminalNode MULTILINESTRING() { return getToken(MariaDBParser.MULTILINESTRING, 0); }
		public TerminalNode MULTIPOINT() { return getToken(MariaDBParser.MULTIPOINT, 0); }
		public TerminalNode MULTIPOLYGON() { return getToken(MariaDBParser.MULTIPOLYGON, 0); }
		public TerminalNode POINT() { return getToken(MariaDBParser.POINT, 0); }
		public TerminalNode POLYGON() { return getToken(MariaDBParser.POLYGON, 0); }
		public TerminalNode JSON() { return getToken(MariaDBParser.JSON, 0); }
		public TerminalNode GEOMETRY() { return getToken(MariaDBParser.GEOMETRY, 0); }
		public SpatialDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSpatialDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSpatialDataType(this);
		}
	}
	public static class LongVarbinaryDataTypeContext extends DataTypeContext {
		public TerminalNode LONG() { return getToken(MariaDBParser.LONG, 0); }
		public TerminalNode VARBINARY() { return getToken(MariaDBParser.VARBINARY, 0); }
		public LongVarbinaryDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterLongVarbinaryDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLongVarbinaryDataType(this);
		}
	}
	public static class CollectionDataTypeContext extends DataTypeContext {
		public Token typeName;
		public CollectionOptionsContext collectionOptions() {
			return getRuleContext(CollectionOptionsContext.class,0);
		}
		public TerminalNode ENUM() { return getToken(MariaDBParser.ENUM, 0); }
		public TerminalNode SET() { return getToken(MariaDBParser.SET, 0); }
		public TerminalNode BINARY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCollectionDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCollectionDataType(this);
		}
	}
	public static class NationalVaryingStringDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode NATIONAL() { return getToken(MariaDBParser.NATIONAL, 0); }
		public TerminalNode VARYING() { return getToken(MariaDBParser.VARYING, 0); }
		public TerminalNode CHAR() { return getToken(MariaDBParser.CHAR, 0); }
		public TerminalNode CHARACTER() { return getToken(MariaDBParser.CHARACTER, 0); }
		public LengthOneDimensionContext lengthOneDimension() {
			return getRuleContext(LengthOneDimensionContext.class,0);
		}
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public NationalVaryingStringDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterNationalVaryingStringDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitNationalVaryingStringDataType(this);
		}
	}
	public static class DimensionDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode TINYINT() { return getToken(MariaDBParser.TINYINT, 0); }
		public TerminalNode SMALLINT() { return getToken(MariaDBParser.SMALLINT, 0); }
		public TerminalNode MEDIUMINT() { return getToken(MariaDBParser.MEDIUMINT, 0); }
		public TerminalNode INT() { return getToken(MariaDBParser.INT, 0); }
		public TerminalNode INTEGER() { return getToken(MariaDBParser.INTEGER, 0); }
		public TerminalNode BIGINT() { return getToken(MariaDBParser.BIGINT, 0); }
		public TerminalNode MIDDLEINT() { return getToken(MariaDBParser.MIDDLEINT, 0); }
		public TerminalNode INT1() { return getToken(MariaDBParser.INT1, 0); }
		public TerminalNode INT2() { return getToken(MariaDBParser.INT2, 0); }
		public TerminalNode INT3() { return getToken(MariaDBParser.INT3, 0); }
		public TerminalNode INT4() { return getToken(MariaDBParser.INT4, 0); }
		public TerminalNode INT8() { return getToken(MariaDBParser.INT8, 0); }
		public LengthOneDimensionContext lengthOneDimension() {
			return getRuleContext(LengthOneDimensionContext.class,0);
		}
		public List SIGNED() { return getTokens(MariaDBParser.SIGNED); }
		public TerminalNode SIGNED(int i) {
			return getToken(MariaDBParser.SIGNED, i);
		}
		public List UNSIGNED() { return getTokens(MariaDBParser.UNSIGNED); }
		public TerminalNode UNSIGNED(int i) {
			return getToken(MariaDBParser.UNSIGNED, i);
		}
		public List ZEROFILL() { return getTokens(MariaDBParser.ZEROFILL); }
		public TerminalNode ZEROFILL(int i) {
			return getToken(MariaDBParser.ZEROFILL, i);
		}
		public TerminalNode REAL() { return getToken(MariaDBParser.REAL, 0); }
		public LengthTwoDimensionContext lengthTwoDimension() {
			return getRuleContext(LengthTwoDimensionContext.class,0);
		}
		public TerminalNode DOUBLE() { return getToken(MariaDBParser.DOUBLE, 0); }
		public TerminalNode PRECISION() { return getToken(MariaDBParser.PRECISION, 0); }
		public TerminalNode DECIMAL() { return getToken(MariaDBParser.DECIMAL, 0); }
		public TerminalNode DEC() { return getToken(MariaDBParser.DEC, 0); }
		public TerminalNode FIXED() { return getToken(MariaDBParser.FIXED, 0); }
		public TerminalNode NUMERIC() { return getToken(MariaDBParser.NUMERIC, 0); }
		public TerminalNode FLOAT() { return getToken(MariaDBParser.FLOAT, 0); }
		public TerminalNode FLOAT4() { return getToken(MariaDBParser.FLOAT4, 0); }
		public TerminalNode FLOAT8() { return getToken(MariaDBParser.FLOAT8, 0); }
		public LengthTwoOptionalDimensionContext lengthTwoOptionalDimension() {
			return getRuleContext(LengthTwoOptionalDimensionContext.class,0);
		}
		public TerminalNode BIT() { return getToken(MariaDBParser.BIT, 0); }
		public TerminalNode TIME() { return getToken(MariaDBParser.TIME, 0); }
		public TerminalNode TIMESTAMP() { return getToken(MariaDBParser.TIMESTAMP, 0); }
		public TerminalNode DATETIME() { return getToken(MariaDBParser.DATETIME, 0); }
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public TerminalNode VARBINARY() { return getToken(MariaDBParser.VARBINARY, 0); }
		public TerminalNode BLOB() { return getToken(MariaDBParser.BLOB, 0); }
		public TerminalNode YEAR() { return getToken(MariaDBParser.YEAR, 0); }
		public DimensionDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterDimensionDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDimensionDataType(this);
		}
	}
	public static class StringDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode CHAR() { return getToken(MariaDBParser.CHAR, 0); }
		public TerminalNode CHARACTER() { return getToken(MariaDBParser.CHARACTER, 0); }
		public TerminalNode VARCHAR() { return getToken(MariaDBParser.VARCHAR, 0); }
		public TerminalNode TINYTEXT() { return getToken(MariaDBParser.TINYTEXT, 0); }
		public TerminalNode TEXT() { return getToken(MariaDBParser.TEXT, 0); }
		public TerminalNode MEDIUMTEXT() { return getToken(MariaDBParser.MEDIUMTEXT, 0); }
		public TerminalNode LONGTEXT() { return getToken(MariaDBParser.LONGTEXT, 0); }
		public TerminalNode NCHAR() { return getToken(MariaDBParser.NCHAR, 0); }
		public TerminalNode NVARCHAR() { return getToken(MariaDBParser.NVARCHAR, 0); }
		public TerminalNode LONG() { return getToken(MariaDBParser.LONG, 0); }
		public TerminalNode VARYING() { return getToken(MariaDBParser.VARYING, 0); }
		public LengthOneDimensionContext lengthOneDimension() {
			return getRuleContext(LengthOneDimensionContext.class,0);
		}
		public List BINARY() { return getTokens(MariaDBParser.BINARY); }
		public TerminalNode BINARY(int i) {
			return getToken(MariaDBParser.BINARY, i);
		}
		public CharSetContext charSet() {
			return getRuleContext(CharSetContext.class,0);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode COLLATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterStringDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitStringDataType(this);
		}
	}
	public static class LongVarcharDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode LONG() { return getToken(MariaDBParser.LONG, 0); }
		public TerminalNode VARCHAR() { return getToken(MariaDBParser.VARCHAR, 0); }
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public CharSetContext charSet() {
			return getRuleContext(CharSetContext.class,0);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode COLLATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLongVarcharDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLongVarcharDataType(this);
		}
	}
	public static class NationalStringDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode NATIONAL() { return getToken(MariaDBParser.NATIONAL, 0); }
		public TerminalNode VARCHAR() { return getToken(MariaDBParser.VARCHAR, 0); }
		public TerminalNode CHARACTER() { return getToken(MariaDBParser.CHARACTER, 0); }
		public TerminalNode CHAR() { return getToken(MariaDBParser.CHAR, 0); }
		public LengthOneDimensionContext lengthOneDimension() {
			return getRuleContext(LengthOneDimensionContext.class,0);
		}
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public TerminalNode NCHAR() { return getToken(MariaDBParser.NCHAR, 0); }
		public NationalStringDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterNationalStringDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitNationalStringDataType(this);
		}
	}
	public static class SimpleDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode DATE() { return getToken(MariaDBParser.DATE, 0); }
		public TerminalNode TINYBLOB() { return getToken(MariaDBParser.TINYBLOB, 0); }
		public TerminalNode MEDIUMBLOB() { return getToken(MariaDBParser.MEDIUMBLOB, 0); }
		public TerminalNode LONGBLOB() { return getToken(MariaDBParser.LONGBLOB, 0); }
		public TerminalNode BOOL() { return getToken(MariaDBParser.BOOL, 0); }
		public TerminalNode BOOLEAN() { return getToken(MariaDBParser.BOOLEAN, 0); }
		public TerminalNode SERIAL() { return getToken(MariaDBParser.SERIAL, 0); }
		public SimpleDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSimpleDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSimpleDataType(this);
		}
	}

	public final DataTypeContext dataType() throws RecognitionException {
		DataTypeContext _localctx = new DataTypeContext(_ctx, getState());
		enterRule(_localctx, 612, RULE_dataType);
		int _la;
		try {
			int _alt;
			setState(6758);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1016,_ctx) ) {
			case 1:
				_localctx = new StringDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(6636);
				((StringDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==CHARACTER || ((((_la - 222)) & ~0x3f) == 0 && ((1L << (_la - 222)) & ((1L << (CHAR - 222)) | (1L << (VARCHAR - 222)) | (1L << (NVARCHAR - 222)) | (1L << (LONG - 222)) | (1L << (TINYTEXT - 222)) | (1L << (TEXT - 222)) | (1L << (MEDIUMTEXT - 222)) | (1L << (LONGTEXT - 222)))) != 0) || _la==NCHAR) ) {
					((StringDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6638);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VARYING) {
					{
					setState(6637);
					match(VARYING);
					}
				}

				setState(6641);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,990,_ctx) ) {
				case 1:
					{
					setState(6640);
					lengthOneDimension();
					}
					break;
				}
				setState(6644);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,991,_ctx) ) {
				case 1:
					{
					setState(6643);
					match(BINARY);
					}
					break;
				}
				setState(6649);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,992,_ctx) ) {
				case 1:
					{
					setState(6646);
					charSet();
					setState(6647);
					charsetName();
					}
					break;
				}
				setState(6654);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,993,_ctx) ) {
				case 1:
					{
					setState(6651);
					match(COLLATE);
					setState(6652);
					collationName();
					}
					break;
				case 2:
					{
					setState(6653);
					match(BINARY);
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new NationalStringDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6656);
				match(NATIONAL);
				setState(6657);
				((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(6659);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,994,_ctx) ) {
				case 1:
					{
					setState(6658);
					lengthOneDimension();
					}
					break;
				}
				setState(6662);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,995,_ctx) ) {
				case 1:
					{
					setState(6661);
					match(BINARY);
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new NationalStringDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(6664);
				match(NCHAR);
				setState(6665);
				((NationalStringDataTypeContext)_localctx).typeName = match(VARCHAR);
				setState(6667);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,996,_ctx) ) {
				case 1:
					{
					setState(6666);
					lengthOneDimension();
					}
					break;
				}
				setState(6670);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,997,_ctx) ) {
				case 1:
					{
					setState(6669);
					match(BINARY);
					}
					break;
				}
				}
				break;
			case 4:
				_localctx = new NationalVaryingStringDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(6672);
				match(NATIONAL);
				setState(6673);
				((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(6674);
				match(VARYING);
				setState(6676);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,998,_ctx) ) {
				case 1:
					{
					setState(6675);
					lengthOneDimension();
					}
					break;
				}
				setState(6679);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,999,_ctx) ) {
				case 1:
					{
					setState(6678);
					match(BINARY);
					}
					break;
				}
				}
				break;
			case 5:
				_localctx = new DimensionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(6681);
				((DimensionDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 196)) & ~0x3f) == 0 && ((1L << (_la - 196)) & ((1L << (TINYINT - 196)) | (1L << (SMALLINT - 196)) | (1L << (MEDIUMINT - 196)) | (1L << (MIDDLEINT - 196)) | (1L << (INT - 196)) | (1L << (INT1 - 196)) | (1L << (INT2 - 196)) | (1L << (INT3 - 196)) | (1L << (INT4 - 196)) | (1L << (INT8 - 196)) | (1L << (INTEGER - 196)) | (1L << (BIGINT - 196)))) != 0)) ) {
					((DimensionDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6683);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1000,_ctx) ) {
				case 1:
					{
					setState(6682);
					lengthOneDimension();
					}
					break;
				}
				setState(6688);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1001,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(6685);
						_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(6690);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,1001,_ctx);
				}
				}
				break;
			case 6:
				_localctx = new DimensionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(6691);
				((DimensionDataTypeContext)_localctx).typeName = match(REAL);
				setState(6693);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1002,_ctx) ) {
				case 1:
					{
					setState(6692);
					lengthTwoDimension();
					}
					break;
				}
				setState(6698);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1003,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(6695);
						_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(6700);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,1003,_ctx);
				}
				}
				break;
			case 7:
				_localctx = new DimensionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(6701);
				((DimensionDataTypeContext)_localctx).typeName = match(DOUBLE);
				setState(6703);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PRECISION) {
					{
					setState(6702);
					match(PRECISION);
					}
				}

				setState(6706);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1005,_ctx) ) {
				case 1:
					{
					setState(6705);
					lengthTwoDimension();
					}
					break;
				}
				setState(6711);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1006,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(6708);
						_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(6713);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,1006,_ctx);
				}
				}
				break;
			case 8:
				_localctx = new DimensionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(6714);
				((DimensionDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 211)) & ~0x3f) == 0 && ((1L << (_la - 211)) & ((1L << (FLOAT - 211)) | (1L << (FLOAT4 - 211)) | (1L << (FLOAT8 - 211)) | (1L << (DECIMAL - 211)) | (1L << (DEC - 211)) | (1L << (NUMERIC - 211)))) != 0) || _la==FIXED) ) {
					((DimensionDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6716);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1007,_ctx) ) {
				case 1:
					{
					setState(6715);
					lengthTwoOptionalDimension();
					}
					break;
				}
				setState(6721);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1008,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(6718);
						_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(6723);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,1008,_ctx);
				}
				}
				break;
			case 9:
				_localctx = new SimpleDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(6724);
				((SimpleDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & ((1L << (DATE - 217)) | (1L << (TINYBLOB - 217)) | (1L << (MEDIUMBLOB - 217)) | (1L << (LONGBLOB - 217)) | (1L << (SERIAL - 217)))) != 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(6725);
				((DimensionDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 218)) & ~0x3f) == 0 && ((1L << (_la - 218)) & ((1L << (TIME - 218)) | (1L << (TIMESTAMP - 218)) | (1L << (DATETIME - 218)) | (1L << (YEAR - 218)) | (1L << (BINARY - 218)) | (1L << (VARBINARY - 218)) | (1L << (BLOB - 218)))) != 0) || _la==BIT) ) {
					((DimensionDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6727);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1009,_ctx) ) {
				case 1:
					{
					setState(6726);
					lengthOneDimension();
					}
					break;
				}
				}
				break;
			case 11:
				_localctx = new CollectionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(6729);
				((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(6730);
				collectionOptions();
				setState(6732);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1010,_ctx) ) {
				case 1:
					{
					setState(6731);
					match(BINARY);
					}
					break;
				}
				setState(6737);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1011,_ctx) ) {
				case 1:
					{
					setState(6734);
					charSet();
					setState(6735);
					charsetName();
					}
					break;
				}
				}
				break;
			case 12:
				_localctx = new SpatialDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(6739);
				((SpatialDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==JSON || ((((_la - 810)) & ~0x3f) == 0 && ((1L << (_la - 810)) & ((1L << (GEOMETRYCOLLECTION - 810)) | (1L << (GEOMCOLLECTION - 810)) | (1L << (GEOMETRY - 810)) | (1L << (LINESTRING - 810)) | (1L << (MULTILINESTRING - 810)) | (1L << (MULTIPOINT - 810)) | (1L << (MULTIPOLYGON - 810)) | (1L << (POINT - 810)) | (1L << (POLYGON - 810)))) != 0)) ) {
					((SpatialDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 13:
				_localctx = new LongVarcharDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(6740);
				((LongVarcharDataTypeContext)_localctx).typeName = match(LONG);
				setState(6742);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VARCHAR) {
					{
					setState(6741);
					match(VARCHAR);
					}
				}

				setState(6745);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1013,_ctx) ) {
				case 1:
					{
					setState(6744);
					match(BINARY);
					}
					break;
				}
				setState(6750);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1014,_ctx) ) {
				case 1:
					{
					setState(6747);
					charSet();
					setState(6748);
					charsetName();
					}
					break;
				}
				setState(6754);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1015,_ctx) ) {
				case 1:
					{
					setState(6752);
					match(COLLATE);
					setState(6753);
					collationName();
					}
					break;
				}
				}
				break;
			case 14:
				_localctx = new LongVarbinaryDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(6756);
				match(LONG);
				setState(6757);
				match(VARBINARY);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CollectionOptionsContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public List collectionOption() {
			return getRuleContexts(CollectionOptionContext.class);
		}
		public CollectionOptionContext collectionOption(int i) {
			return getRuleContext(CollectionOptionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCollectionOptions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCollectionOptions(this);
		}
	}

	public final CollectionOptionsContext collectionOptions() throws RecognitionException {
		CollectionOptionsContext _localctx = new CollectionOptionsContext(_ctx, getState());
		enterRule(_localctx, 614, RULE_collectionOptions);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6760);
			match(LR_BRACKET);
			setState(6761);
			collectionOption();
			setState(6766);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6762);
				match(COMMA);
				setState(6763);
				collectionOption();
				}
				}
				setState(6768);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(6769);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CollectionOptionContext extends ParserRuleContext {
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public CollectionOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_collectionOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterCollectionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCollectionOption(this);
		}
	}

	public final CollectionOptionContext collectionOption() throws RecognitionException {
		CollectionOptionContext _localctx = new CollectionOptionContext(_ctx, getState());
		enterRule(_localctx, 616, RULE_collectionOption);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6771);
			match(STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class ConvertedDataTypeContext extends ParserRuleContext {
		public Token typeName;
		public TerminalNode CHAR() { return getToken(MariaDBParser.CHAR, 0); }
		public TerminalNode DECIMAL() { return getToken(MariaDBParser.DECIMAL, 0); }
		public TerminalNode SIGNED() { return getToken(MariaDBParser.SIGNED, 0); }
		public TerminalNode UNSIGNED() { return getToken(MariaDBParser.UNSIGNED, 0); }
		public TerminalNode ARRAY() { return getToken(MariaDBParser.ARRAY, 0); }
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public TerminalNode NCHAR() { return getToken(MariaDBParser.NCHAR, 0); }
		public TerminalNode DATE() { return getToken(MariaDBParser.DATE, 0); }
		public TerminalNode DATETIME() { return getToken(MariaDBParser.DATETIME, 0); }
		public TerminalNode TIME() { return getToken(MariaDBParser.TIME, 0); }
		public TerminalNode JSON() { return getToken(MariaDBParser.JSON, 0); }
		public TerminalNode INT() { return getToken(MariaDBParser.INT, 0); }
		public TerminalNode INTEGER() { return getToken(MariaDBParser.INTEGER, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterConvertedDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitConvertedDataType(this);
		}
	}

	public final ConvertedDataTypeContext convertedDataType() throws RecognitionException {
		ConvertedDataTypeContext _localctx = new ConvertedDataTypeContext(_ctx, getState());
		enterRule(_localctx, 618, RULE_convertedDataType);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6795);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case BINARY:
			case NCHAR:
				{
				setState(6773);
				((ConvertedDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_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(6775);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(6774);
					lengthOneDimension();
					}
				}

				}
				break;
			case CHAR:
				{
				setState(6777);
				((ConvertedDataTypeContext)_localctx).typeName = match(CHAR);
				setState(6779);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(6778);
					lengthOneDimension();
					}
				}

				setState(6784);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CHARACTER || _la==CHAR || _la==CHARSET) {
					{
					setState(6781);
					charSet();
					setState(6782);
					charsetName();
					}
				}

				}
				break;
			case INT:
			case INTEGER:
			case DATE:
			case TIME:
			case DATETIME:
			case JSON:
				{
				setState(6786);
				((ConvertedDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 200)) & ~0x3f) == 0 && ((1L << (_la - 200)) & ((1L << (INT - 200)) | (1L << (INTEGER - 200)) | (1L << (DATE - 200)) | (1L << (TIME - 200)) | (1L << (DATETIME - 200)))) != 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:
				{
				setState(6787);
				((ConvertedDataTypeContext)_localctx).typeName = match(DECIMAL);
				setState(6789);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(6788);
					lengthTwoOptionalDimension();
					}
				}

				}
				break;
			case UNSIGNED:
			case SIGNED:
				{
				setState(6791);
				_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(6793);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INTEGER) {
					{
					setState(6792);
					match(INTEGER);
					}
				}

				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(6798);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ARRAY) {
				{
				setState(6797);
				match(ARRAY);
				}
			}

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

	public static class LengthOneDimensionContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLengthOneDimension(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLengthOneDimension(this);
		}
	}

	public final LengthOneDimensionContext lengthOneDimension() throws RecognitionException {
		LengthOneDimensionContext _localctx = new LengthOneDimensionContext(_ctx, getState());
		enterRule(_localctx, 620, RULE_lengthOneDimension);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6800);
			match(LR_BRACKET);
			setState(6801);
			decimalLiteral();
			setState(6802);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class LengthTwoDimensionContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.COMMA, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLengthTwoDimension(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLengthTwoDimension(this);
		}
	}

	public final LengthTwoDimensionContext lengthTwoDimension() throws RecognitionException {
		LengthTwoDimensionContext _localctx = new LengthTwoDimensionContext(_ctx, getState());
		enterRule(_localctx, 622, RULE_lengthTwoDimension);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6804);
			match(LR_BRACKET);
			setState(6805);
			decimalLiteral();
			setState(6806);
			match(COMMA);
			setState(6807);
			decimalLiteral();
			setState(6808);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class LengthTwoOptionalDimensionContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode COMMA() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLengthTwoOptionalDimension(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLengthTwoOptionalDimension(this);
		}
	}

	public final LengthTwoOptionalDimensionContext lengthTwoOptionalDimension() throws RecognitionException {
		LengthTwoOptionalDimensionContext _localctx = new LengthTwoOptionalDimensionContext(_ctx, getState());
		enterRule(_localctx, 624, RULE_lengthTwoOptionalDimension);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6810);
			match(LR_BRACKET);
			setState(6811);
			decimalLiteral();
			setState(6814);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMA) {
				{
				setState(6812);
				match(COMMA);
				setState(6813);
				decimalLiteral();
				}
			}

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

	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUidList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUidList(this);
		}
	}

	public final UidListContext uidList() throws RecognitionException {
		UidListContext _localctx = new UidListContext(_ctx, getState());
		enterRule(_localctx, 626, RULE_uidList);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(6818);
			uid();
			setState(6823);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,1026,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(6819);
					match(COMMA);
					setState(6820);
					uid();
					}
					} 
				}
				setState(6825);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1026,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTables(this);
		}
	}

	public final TablesContext tables() throws RecognitionException {
		TablesContext _localctx = new TablesContext(_ctx, getState());
		enterRule(_localctx, 628, RULE_tables);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(6826);
			tableName();
			setState(6831);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,1027,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(6827);
					match(COMMA);
					setState(6828);
					tableName();
					}
					} 
				}
				setState(6833);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1027,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class IndexColumnNamesContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIndexColumnNames(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIndexColumnNames(this);
		}
	}

	public final IndexColumnNamesContext indexColumnNames() throws RecognitionException {
		IndexColumnNamesContext _localctx = new IndexColumnNamesContext(_ctx, getState());
		enterRule(_localctx, 630, RULE_indexColumnNames);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6834);
			match(LR_BRACKET);
			setState(6835);
			indexColumnName();
			setState(6840);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6836);
				match(COMMA);
				setState(6837);
				indexColumnName();
				}
				}
				setState(6842);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(6843);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterExpressions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitExpressions(this);
		}
	}

	public final ExpressionsContext expressions() throws RecognitionException {
		ExpressionsContext _localctx = new ExpressionsContext(_ctx, getState());
		enterRule(_localctx, 632, RULE_expressions);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6845);
			expression(0);
			setState(6850);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6846);
				match(COMMA);
				setState(6847);
				expression(0);
				}
				}
				setState(6852);
				_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;
	}

	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterExpressionsWithDefaults(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitExpressionsWithDefaults(this);
		}
	}

	public final ExpressionsWithDefaultsContext expressionsWithDefaults() throws RecognitionException {
		ExpressionsWithDefaultsContext _localctx = new ExpressionsWithDefaultsContext(_ctx, getState());
		enterRule(_localctx, 634, RULE_expressionsWithDefaults);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6853);
			expressionOrDefault();
			setState(6858);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6854);
				match(COMMA);
				setState(6855);
				expressionOrDefault();
				}
				}
				setState(6860);
				_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;
	}

	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterConstants(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitConstants(this);
		}
	}

	public final ConstantsContext constants() throws RecognitionException {
		ConstantsContext _localctx = new ConstantsContext(_ctx, getState());
		enterRule(_localctx, 636, RULE_constants);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6861);
			constant();
			setState(6866);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6862);
				match(COMMA);
				setState(6863);
				constant();
				}
				}
				setState(6868);
				_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;
	}

	public static class SimpleStringsContext extends ParserRuleContext {
		public List STRING_LITERAL() { return getTokens(MariaDBParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MariaDBParser.STRING_LITERAL, i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSimpleStrings(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSimpleStrings(this);
		}
	}

	public final SimpleStringsContext simpleStrings() throws RecognitionException {
		SimpleStringsContext _localctx = new SimpleStringsContext(_ctx, getState());
		enterRule(_localctx, 638, RULE_simpleStrings);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6869);
			match(STRING_LITERAL);
			setState(6874);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6870);
				match(COMMA);
				setState(6871);
				match(STRING_LITERAL);
				}
				}
				setState(6876);
				_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;
	}

	public static class UserVariablesContext extends ParserRuleContext {
		public List LOCAL_ID() { return getTokens(MariaDBParser.LOCAL_ID); }
		public TerminalNode LOCAL_ID(int i) {
			return getToken(MariaDBParser.LOCAL_ID, i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUserVariables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUserVariables(this);
		}
	}

	public final UserVariablesContext userVariables() throws RecognitionException {
		UserVariablesContext _localctx = new UserVariablesContext(_ctx, getState());
		enterRule(_localctx, 640, RULE_userVariables);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6877);
			match(LOCAL_ID);
			setState(6882);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6878);
				match(COMMA);
				setState(6879);
				match(LOCAL_ID);
				}
				}
				setState(6884);
				_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;
	}

	public static class DefaultValueContext extends ParserRuleContext {
		public TerminalNode NULL_LITERAL() { return getToken(MariaDBParser.NULL_LITERAL, 0); }
		public TerminalNode CAST() { return getToken(MariaDBParser.CAST, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public ConvertedDataTypeContext convertedDataType() {
			return getRuleContext(ConvertedDataTypeContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.ON, 0); }
		public TerminalNode UPDATE() { return getToken(MariaDBParser.UPDATE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode LASTVAL() { return getToken(MariaDBParser.LASTVAL, 0); }
		public TerminalNode NEXTVAL() { return getToken(MariaDBParser.NEXTVAL, 0); }
		public TerminalNode VALUE() { return getToken(MariaDBParser.VALUE, 0); }
		public TerminalNode FOR() { return getToken(MariaDBParser.FOR, 0); }
		public TerminalNode PREVIOUS() { return getToken(MariaDBParser.PREVIOUS, 0); }
		public TerminalNode NEXT() { return getToken(MariaDBParser.NEXT, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDefaultValue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDefaultValue(this);
		}
	}

	public final DefaultValueContext defaultValue() throws RecognitionException {
		DefaultValueContext _localctx = new DefaultValueContext(_ctx, getState());
		enterRule(_localctx, 642, RULE_defaultValue);
		int _la;
		try {
			setState(6920);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1036,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6885);
				match(NULL_LITERAL);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6886);
				match(CAST);
				setState(6887);
				match(LR_BRACKET);
				setState(6888);
				expression(0);
				setState(6889);
				match(AS);
				setState(6890);
				convertedDataType();
				setState(6891);
				match(RR_BRACKET);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6894);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1034,_ctx) ) {
				case 1:
					{
					setState(6893);
					unaryOperator();
					}
					break;
				}
				setState(6896);
				constant();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(6897);
				currentTimestamp();
				setState(6901);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1035,_ctx) ) {
				case 1:
					{
					setState(6898);
					match(ON);
					setState(6899);
					match(UPDATE);
					setState(6900);
					currentTimestamp();
					}
					break;
				}
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(6903);
				match(LR_BRACKET);
				setState(6904);
				expression(0);
				setState(6905);
				match(RR_BRACKET);
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(6907);
				_la = _input.LA(1);
				if ( !(_la==LASTVAL || _la==NEXTVAL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6908);
				match(LR_BRACKET);
				setState(6909);
				fullId();
				setState(6910);
				match(RR_BRACKET);
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(6912);
				match(LR_BRACKET);
				setState(6913);
				_la = _input.LA(1);
				if ( !(_la==NEXT || _la==PREVIOUS) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6914);
				match(VALUE);
				setState(6915);
				match(FOR);
				setState(6916);
				fullId();
				setState(6917);
				match(RR_BRACKET);
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(6919);
				expression(0);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CurrentTimestampContext extends ParserRuleContext {
		public TerminalNode NOW() { return getToken(MariaDBParser.NOW, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode CURRENT_TIMESTAMP() { return getToken(MariaDBParser.CURRENT_TIMESTAMP, 0); }
		public TerminalNode LOCALTIME() { return getToken(MariaDBParser.LOCALTIME, 0); }
		public TerminalNode LOCALTIMESTAMP() { return getToken(MariaDBParser.LOCALTIMESTAMP, 0); }
		public TerminalNode CURDATE() { return getToken(MariaDBParser.CURDATE, 0); }
		public TerminalNode CURTIME() { return getToken(MariaDBParser.CURTIME, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCurrentTimestamp(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCurrentTimestamp(this);
		}
	}

	public final CurrentTimestampContext currentTimestamp() throws RecognitionException {
		CurrentTimestampContext _localctx = new CurrentTimestampContext(_ctx, getState());
		enterRule(_localctx, 644, RULE_currentTimestamp);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6936);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case CURDATE:
			case CURTIME:
			case LOCALTIMESTAMP:
				{
				setState(6922);
				_la = _input.LA(1);
				if ( !(((((_la - 315)) & ~0x3f) == 0 && ((1L << (_la - 315)) & ((1L << (CURRENT_TIMESTAMP - 315)) | (1L << (LOCALTIME - 315)) | (1L << (CURDATE - 315)) | (1L << (CURTIME - 315)) | (1L << (LOCALTIMESTAMP - 315)))) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6928);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1038,_ctx) ) {
				case 1:
					{
					setState(6923);
					match(LR_BRACKET);
					setState(6925);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (((((_la - 1159)) & ~0x3f) == 0 && ((1L << (_la - 1159)) & ((1L << (ZERO_DECIMAL - 1159)) | (1L << (ONE_DECIMAL - 1159)) | (1L << (TWO_DECIMAL - 1159)) | (1L << (DECIMAL_LITERAL - 1159)) | (1L << (REAL_LITERAL - 1159)))) != 0)) {
						{
						setState(6924);
						decimalLiteral();
						}
					}

					setState(6927);
					match(RR_BRACKET);
					}
					break;
				}
				}
				break;
			case NOW:
				{
				setState(6930);
				match(NOW);
				setState(6931);
				match(LR_BRACKET);
				setState(6933);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 1159)) & ~0x3f) == 0 && ((1L << (_la - 1159)) & ((1L << (ZERO_DECIMAL - 1159)) | (1L << (ONE_DECIMAL - 1159)) | (1L << (TWO_DECIMAL - 1159)) | (1L << (DECIMAL_LITERAL - 1159)) | (1L << (REAL_LITERAL - 1159)))) != 0)) {
					{
					setState(6932);
					decimalLiteral();
					}
				}

				setState(6935);
				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;
	}

	public static class ExpressionOrDefaultContext extends ParserRuleContext {
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterExpressionOrDefault(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitExpressionOrDefault(this);
		}
	}

	public final ExpressionOrDefaultContext expressionOrDefault() throws RecognitionException {
		ExpressionOrDefaultContext _localctx = new ExpressionOrDefaultContext(_ctx, getState());
		enterRule(_localctx, 646, RULE_expressionOrDefault);
		try {
			setState(6940);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1041,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6938);
				expression(0);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6939);
				match(DEFAULT);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class IfExistsContext extends ParserRuleContext {
		public TerminalNode IF() { return getToken(MariaDBParser.IF, 0); }
		public TerminalNode EXISTS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIfExists(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIfExists(this);
		}
	}

	public final IfExistsContext ifExists() throws RecognitionException {
		IfExistsContext _localctx = new IfExistsContext(_ctx, getState());
		enterRule(_localctx, 648, RULE_ifExists);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6942);
			match(IF);
			setState(6943);
			match(EXISTS);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class IfNotExistsContext extends ParserRuleContext {
		public TerminalNode IF() { return getToken(MariaDBParser.IF, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.NOT, 0); }
		public TerminalNode EXISTS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIfNotExists(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIfNotExists(this);
		}
	}

	public final IfNotExistsContext ifNotExists() throws RecognitionException {
		IfNotExistsContext _localctx = new IfNotExistsContext(_ctx, getState());
		enterRule(_localctx, 650, RULE_ifNotExists);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6945);
			match(IF);
			setState(6946);
			match(NOT);
			setState(6947);
			match(EXISTS);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class OrReplaceContext extends ParserRuleContext {
		public TerminalNode OR() { return getToken(MariaDBParser.OR, 0); }
		public TerminalNode REPLACE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterOrReplace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitOrReplace(this);
		}
	}

	public final OrReplaceContext orReplace() throws RecognitionException {
		OrReplaceContext _localctx = new OrReplaceContext(_ctx, getState());
		enterRule(_localctx, 652, RULE_orReplace);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6949);
			match(OR);
			setState(6950);
			match(REPLACE);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class WaitNowaitClauseContext extends ParserRuleContext {
		public TerminalNode WAIT() { return getToken(MariaDBParser.WAIT, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode NOWAIT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterWaitNowaitClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitWaitNowaitClause(this);
		}
	}

	public final WaitNowaitClauseContext waitNowaitClause() throws RecognitionException {
		WaitNowaitClauseContext _localctx = new WaitNowaitClauseContext(_ctx, getState());
		enterRule(_localctx, 654, RULE_waitNowaitClause);
		try {
			setState(6955);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case WAIT:
				enterOuterAlt(_localctx, 1);
				{
				setState(6952);
				match(WAIT);
				setState(6953);
				decimalLiteral();
				}
				break;
			case NOWAIT:
				enterOuterAlt(_localctx, 2);
				{
				setState(6954);
				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;
	}

	public static class LockOptionContext extends ParserRuleContext {
		public WaitNowaitClauseContext waitNowaitClause() {
			return getRuleContext(WaitNowaitClauseContext.class,0);
		}
		public TerminalNode SKIP_() { return getToken(MariaDBParser.SKIP_, 0); }
		public TerminalNode LOCKED() { return getToken(MariaDBParser.LOCKED, 0); }
		public LockOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_lockOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterLockOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLockOption(this);
		}
	}

	public final LockOptionContext lockOption() throws RecognitionException {
		LockOptionContext _localctx = new LockOptionContext(_ctx, getState());
		enterRule(_localctx, 656, RULE_lockOption);
		try {
			setState(6960);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case NOWAIT:
			case WAIT:
				enterOuterAlt(_localctx, 1);
				{
				setState(6957);
				waitNowaitClause();
				}
				break;
			case SKIP_:
				enterOuterAlt(_localctx, 2);
				{
				setState(6958);
				match(SKIP_);
				setState(6959);
				match(LOCKED);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterSpecificFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSpecificFunctionCall(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPasswordFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPasswordFunctionCall(this);
		}
	}
	public static class UdfFunctionCallContext extends FunctionCallContext {
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUdfFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUdfFunctionCall(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterNonAggregateFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitNonAggregateFunctionCall(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAggregateFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAggregateFunctionCall(this);
		}
	}
	public static class ScalarFunctionCallContext extends FunctionCallContext {
		public ScalarFunctionNameContext scalarFunctionName() {
			return getRuleContext(ScalarFunctionNameContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterScalarFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitScalarFunctionCall(this);
		}
	}

	public final FunctionCallContext functionCall() throws RecognitionException {
		FunctionCallContext _localctx = new FunctionCallContext(_ctx, getState());
		enterRule(_localctx, 658, RULE_functionCall);
		try {
			setState(6980);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1046,_ctx) ) {
			case 1:
				_localctx = new SpecificFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(6962);
				specificFunction();
				}
				break;
			case 2:
				_localctx = new AggregateFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6963);
				aggregateWindowedFunction();
				}
				break;
			case 3:
				_localctx = new NonAggregateFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(6964);
				nonAggregateWindowedFunction();
				}
				break;
			case 4:
				_localctx = new ScalarFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(6965);
				scalarFunctionName();
				setState(6966);
				match(LR_BRACKET);
				setState(6968);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1044,_ctx) ) {
				case 1:
					{
					setState(6967);
					functionArgs();
					}
					break;
				}
				setState(6970);
				match(RR_BRACKET);
				}
				break;
			case 5:
				_localctx = new UdfFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(6972);
				fullId();
				setState(6973);
				match(LR_BRACKET);
				setState(6975);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1045,_ctx) ) {
				case 1:
					{
					setState(6974);
					functionArgs();
					}
					break;
				}
				setState(6977);
				match(RR_BRACKET);
				}
				break;
			case 6:
				_localctx = new PasswordFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(6979);
				passwordFunctionClause();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class PositionFunctionCallContext extends SpecificFunctionContext {
		public StringLiteralContext positionString;
		public ExpressionContext positionExpression;
		public StringLiteralContext inString;
		public ExpressionContext inExpression;
		public TerminalNode POSITION() { return getToken(MariaDBParser.POSITION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode IN() { return getToken(MariaDBParser.IN, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPositionFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPositionFunctionCall(this);
		}
	}
	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(MariaDBParser.TRIM, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode BOTH() { return getToken(MariaDBParser.BOTH, 0); }
		public TerminalNode LEADING() { return getToken(MariaDBParser.LEADING, 0); }
		public TerminalNode TRAILING() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTrimFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTrimFunctionCall(this);
		}
	}
	public static class JsonValueFunctionCallContext extends SpecificFunctionContext {
		public TerminalNode JSON_VALUE() { return getToken(MariaDBParser.JSON_VALUE, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.COMMA, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode RETURNING() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterJsonValueFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitJsonValueFunctionCall(this);
		}
	}
	public static class CaseFunctionCallContext extends SpecificFunctionContext {
		public FunctionArgContext elseArg;
		public TerminalNode CASE() { return getToken(MariaDBParser.CASE, 0); }
		public TerminalNode END() { return getToken(MariaDBParser.END, 0); }
		public List caseFuncAlternative() {
			return getRuleContexts(CaseFuncAlternativeContext.class);
		}
		public CaseFuncAlternativeContext caseFuncAlternative(int i) {
			return getRuleContext(CaseFuncAlternativeContext.class,i);
		}
		public TerminalNode ELSE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCaseFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCaseFunctionCall(this);
		}
	}
	public static class ExtractFunctionCallContext extends SpecificFunctionContext {
		public StringLiteralContext sourceString;
		public ExpressionContext sourceExpression;
		public TerminalNode EXTRACT() { return getToken(MariaDBParser.EXTRACT, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public IntervalTypeContext intervalType() {
			return getRuleContext(IntervalTypeContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterExtractFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitExtractFunctionCall(this);
		}
	}
	public static class DataTypeFunctionCallContext extends SpecificFunctionContext {
		public Token separator;
		public TerminalNode CONVERT() { return getToken(MariaDBParser.CONVERT, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode COMMA() { return getToken(MariaDBParser.COMMA, 0); }
		public TerminalNode USING() { return getToken(MariaDBParser.USING, 0); }
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode CAST() { return getToken(MariaDBParser.CAST, 0); }
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public DataTypeFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterDataTypeFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDataTypeFunctionCall(this);
		}
	}
	public static class ValuesFunctionCallContext extends SpecificFunctionContext {
		public TerminalNode VALUES() { return getToken(MariaDBParser.VALUES, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public FullColumnNameContext fullColumnName() {
			return getRuleContext(FullColumnNameContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public ValuesFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterValuesFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitValuesFunctionCall(this);
		}
	}
	public static class CaseExpressionFunctionCallContext extends SpecificFunctionContext {
		public FunctionArgContext elseArg;
		public TerminalNode CASE() { return getToken(MariaDBParser.CASE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode END() { return getToken(MariaDBParser.END, 0); }
		public List caseFuncAlternative() {
			return getRuleContexts(CaseFuncAlternativeContext.class);
		}
		public CaseFuncAlternativeContext caseFuncAlternative(int i) {
			return getRuleContext(CaseFuncAlternativeContext.class,i);
		}
		public TerminalNode ELSE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCaseExpressionFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCaseExpressionFunctionCall(this);
		}
	}
	public static class SimpleFunctionCallContext extends SpecificFunctionContext {
		public TerminalNode CURRENT_DATE() { return getToken(MariaDBParser.CURRENT_DATE, 0); }
		public TerminalNode CURRENT_TIME() { return getToken(MariaDBParser.CURRENT_TIME, 0); }
		public TerminalNode CURRENT_TIMESTAMP() { return getToken(MariaDBParser.CURRENT_TIMESTAMP, 0); }
		public TerminalNode CURDATE() { return getToken(MariaDBParser.CURDATE, 0); }
		public TerminalNode CURTIME() { return getToken(MariaDBParser.CURTIME, 0); }
		public TerminalNode CURRENT_USER() { return getToken(MariaDBParser.CURRENT_USER, 0); }
		public TerminalNode LOCALTIME() { return getToken(MariaDBParser.LOCALTIME, 0); }
		public TerminalNode UTC_TIMESTAMP() { return getToken(MariaDBParser.UTC_TIMESTAMP, 0); }
		public TerminalNode SCHEMA() { return getToken(MariaDBParser.SCHEMA, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public SimpleFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSimpleFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSimpleFunctionCall(this);
		}
	}
	public static class CharFunctionCallContext extends SpecificFunctionContext {
		public TerminalNode CHAR() { return getToken(MariaDBParser.CHAR, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public FunctionArgsContext functionArgs() {
			return getRuleContext(FunctionArgsContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode USING() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCharFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCharFunctionCall(this);
		}
	}
	public static class WeightFunctionCallContext extends SpecificFunctionContext {
		public Token stringFormat;
		public TerminalNode WEIGHT_STRING() { return getToken(MariaDBParser.WEIGHT_STRING, 0); }
		public List LR_BRACKET() { return getTokens(MariaDBParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MariaDBParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MariaDBParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MariaDBParser.RR_BRACKET, i);
		}
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode AS() { return getToken(MariaDBParser.AS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public LevelsInWeightStringContext levelsInWeightString() {
			return getRuleContext(LevelsInWeightStringContext.class,0);
		}
		public TerminalNode CHAR() { return getToken(MariaDBParser.CHAR, 0); }
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public WeightFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterWeightFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitWeightFunctionCall(this);
		}
	}
	public static class GetFormatFunctionCallContext extends SpecificFunctionContext {
		public Token datetimeFormat;
		public TerminalNode GET_FORMAT() { return getToken(MariaDBParser.GET_FORMAT, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode COMMA() { return getToken(MariaDBParser.COMMA, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode DATE() { return getToken(MariaDBParser.DATE, 0); }
		public TerminalNode TIME() { return getToken(MariaDBParser.TIME, 0); }
		public TerminalNode DATETIME() { return getToken(MariaDBParser.DATETIME, 0); }
		public GetFormatFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterGetFormatFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitGetFormatFunctionCall(this);
		}
	}
	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(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode FROM() { return getToken(MariaDBParser.FROM, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode SUBSTR() { return getToken(MariaDBParser.SUBSTR, 0); }
		public TerminalNode SUBSTRING() { return getToken(MariaDBParser.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(MariaDBParser.FOR, 0); }
		public SubstrFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSubstrFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSubstrFunctionCall(this);
		}
	}

	public final SpecificFunctionContext specificFunction() throws RecognitionException {
		SpecificFunctionContext _localctx = new SpecificFunctionContext(_ctx, getState());
		enterRule(_localctx, 660, RULE_specificFunction);
		int _la;
		try {
			setState(7160);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1070,_ctx) ) {
			case 1:
				_localctx = new SimpleFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(6982);
				_la = _input.LA(1);
				if ( !(_la==CURRENT_USER || _la==SCHEMA || ((((_la - 313)) & ~0x3f) == 0 && ((1L << (_la - 313)) & ((1L << (CURRENT_DATE - 313)) | (1L << (CURRENT_TIME - 313)) | (1L << (CURRENT_TIMESTAMP - 313)) | (1L << (LOCALTIME - 313)) | (1L << (CURDATE - 313)) | (1L << (CURTIME - 313)) | (1L << (UTC_TIMESTAMP - 313)))) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6985);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1047,_ctx) ) {
				case 1:
					{
					setState(6983);
					match(LR_BRACKET);
					setState(6984);
					match(RR_BRACKET);
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new DataTypeFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6987);
				match(CONVERT);
				setState(6988);
				match(LR_BRACKET);
				setState(6989);
				expression(0);
				setState(6990);
				((DataTypeFunctionCallContext)_localctx).separator = match(COMMA);
				setState(6991);
				convertedDataType();
				setState(6992);
				match(RR_BRACKET);
				}
				break;
			case 3:
				_localctx = new DataTypeFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(6994);
				match(CONVERT);
				setState(6995);
				match(LR_BRACKET);
				setState(6996);
				expression(0);
				setState(6997);
				match(USING);
				setState(6998);
				charsetName();
				setState(6999);
				match(RR_BRACKET);
				}
				break;
			case 4:
				_localctx = new DataTypeFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(7001);
				match(CAST);
				setState(7002);
				match(LR_BRACKET);
				setState(7003);
				expression(0);
				setState(7004);
				match(AS);
				setState(7005);
				convertedDataType();
				setState(7006);
				match(RR_BRACKET);
				}
				break;
			case 5:
				_localctx = new ValuesFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(7008);
				match(VALUES);
				setState(7009);
				match(LR_BRACKET);
				setState(7010);
				fullColumnName();
				setState(7011);
				match(RR_BRACKET);
				}
				break;
			case 6:
				_localctx = new CaseExpressionFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(7013);
				match(CASE);
				setState(7014);
				expression(0);
				setState(7016); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(7015);
					caseFuncAlternative();
					}
					}
					setState(7018); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(7022);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(7020);
					match(ELSE);
					setState(7021);
					((CaseExpressionFunctionCallContext)_localctx).elseArg = functionArg();
					}
				}

				setState(7024);
				match(END);
				}
				break;
			case 7:
				_localctx = new CaseFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(7026);
				match(CASE);
				setState(7028); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(7027);
					caseFuncAlternative();
					}
					}
					setState(7030); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(7034);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(7032);
					match(ELSE);
					setState(7033);
					((CaseFunctionCallContext)_localctx).elseArg = functionArg();
					}
				}

				setState(7036);
				match(END);
				}
				break;
			case 8:
				_localctx = new CharFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(7038);
				match(CHAR);
				setState(7039);
				match(LR_BRACKET);
				setState(7040);
				functionArgs();
				setState(7043);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==USING) {
					{
					setState(7041);
					match(USING);
					setState(7042);
					charsetName();
					}
				}

				setState(7045);
				match(RR_BRACKET);
				}
				break;
			case 9:
				_localctx = new PositionFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(7047);
				match(POSITION);
				setState(7048);
				match(LR_BRACKET);
				setState(7051);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1053,_ctx) ) {
				case 1:
					{
					setState(7049);
					((PositionFunctionCallContext)_localctx).positionString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(7050);
					((PositionFunctionCallContext)_localctx).positionExpression = expression(0);
					}
					break;
				}
				setState(7053);
				match(IN);
				setState(7056);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1054,_ctx) ) {
				case 1:
					{
					setState(7054);
					((PositionFunctionCallContext)_localctx).inString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(7055);
					((PositionFunctionCallContext)_localctx).inExpression = expression(0);
					}
					break;
				}
				setState(7058);
				match(RR_BRACKET);
				}
				break;
			case 10:
				_localctx = new SubstrFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(7060);
				_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(7061);
				match(LR_BRACKET);
				setState(7064);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1055,_ctx) ) {
				case 1:
					{
					setState(7062);
					((SubstrFunctionCallContext)_localctx).sourceString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(7063);
					((SubstrFunctionCallContext)_localctx).sourceExpression = expression(0);
					}
					break;
				}
				setState(7066);
				match(FROM);
				setState(7069);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1056,_ctx) ) {
				case 1:
					{
					setState(7067);
					((SubstrFunctionCallContext)_localctx).fromDecimal = decimalLiteral();
					}
					break;
				case 2:
					{
					setState(7068);
					((SubstrFunctionCallContext)_localctx).fromExpression = expression(0);
					}
					break;
				}
				setState(7076);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(7071);
					match(FOR);
					setState(7074);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,1057,_ctx) ) {
					case 1:
						{
						setState(7072);
						((SubstrFunctionCallContext)_localctx).forDecimal = decimalLiteral();
						}
						break;
					case 2:
						{
						setState(7073);
						((SubstrFunctionCallContext)_localctx).forExpression = expression(0);
						}
						break;
					}
					}
				}

				setState(7078);
				match(RR_BRACKET);
				}
				break;
			case 11:
				_localctx = new TrimFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(7080);
				match(TRIM);
				setState(7081);
				match(LR_BRACKET);
				setState(7082);
				((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(7085);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1059,_ctx) ) {
				case 1:
					{
					setState(7083);
					((TrimFunctionCallContext)_localctx).sourceString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(7084);
					((TrimFunctionCallContext)_localctx).sourceExpression = expression(0);
					}
					break;
				}
				setState(7087);
				match(FROM);
				setState(7090);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1060,_ctx) ) {
				case 1:
					{
					setState(7088);
					((TrimFunctionCallContext)_localctx).fromString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(7089);
					((TrimFunctionCallContext)_localctx).fromExpression = expression(0);
					}
					break;
				}
				setState(7092);
				match(RR_BRACKET);
				}
				break;
			case 12:
				_localctx = new TrimFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(7094);
				match(TRIM);
				setState(7095);
				match(LR_BRACKET);
				setState(7098);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1061,_ctx) ) {
				case 1:
					{
					setState(7096);
					((TrimFunctionCallContext)_localctx).sourceString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(7097);
					((TrimFunctionCallContext)_localctx).sourceExpression = expression(0);
					}
					break;
				}
				setState(7100);
				match(FROM);
				setState(7103);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1062,_ctx) ) {
				case 1:
					{
					setState(7101);
					((TrimFunctionCallContext)_localctx).fromString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(7102);
					((TrimFunctionCallContext)_localctx).fromExpression = expression(0);
					}
					break;
				}
				setState(7105);
				match(RR_BRACKET);
				}
				break;
			case 13:
				_localctx = new WeightFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(7107);
				match(WEIGHT_STRING);
				setState(7108);
				match(LR_BRACKET);
				setState(7111);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1063,_ctx) ) {
				case 1:
					{
					setState(7109);
					stringLiteral();
					}
					break;
				case 2:
					{
					setState(7110);
					expression(0);
					}
					break;
				}
				setState(7119);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(7113);
					match(AS);
					setState(7114);
					((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(7115);
					match(LR_BRACKET);
					setState(7116);
					decimalLiteral();
					setState(7117);
					match(RR_BRACKET);
					}
				}

				setState(7122);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LEVEL) {
					{
					setState(7121);
					levelsInWeightString();
					}
				}

				setState(7124);
				match(RR_BRACKET);
				}
				break;
			case 14:
				_localctx = new ExtractFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(7126);
				match(EXTRACT);
				setState(7127);
				match(LR_BRACKET);
				setState(7128);
				intervalType();
				setState(7129);
				match(FROM);
				setState(7132);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1066,_ctx) ) {
				case 1:
					{
					setState(7130);
					((ExtractFunctionCallContext)_localctx).sourceString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(7131);
					((ExtractFunctionCallContext)_localctx).sourceExpression = expression(0);
					}
					break;
				}
				setState(7134);
				match(RR_BRACKET);
				}
				break;
			case 15:
				_localctx = new GetFormatFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(7136);
				match(GET_FORMAT);
				setState(7137);
				match(LR_BRACKET);
				setState(7138);
				((GetFormatFunctionCallContext)_localctx).datetimeFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & ((1L << (DATE - 217)) | (1L << (TIME - 217)) | (1L << (DATETIME - 217)))) != 0)) ) {
					((GetFormatFunctionCallContext)_localctx).datetimeFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(7139);
				match(COMMA);
				setState(7140);
				stringLiteral();
				setState(7141);
				match(RR_BRACKET);
				}
				break;
			case 16:
				_localctx = new JsonValueFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 16);
				{
				setState(7143);
				match(JSON_VALUE);
				setState(7144);
				match(LR_BRACKET);
				setState(7145);
				expression(0);
				setState(7146);
				match(COMMA);
				setState(7147);
				expression(0);
				setState(7150);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==RETURNING) {
					{
					setState(7148);
					match(RETURNING);
					setState(7149);
					convertedDataType();
					}
				}

				setState(7153);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1068,_ctx) ) {
				case 1:
					{
					setState(7152);
					jsonOnEmpty();
					}
					break;
				}
				setState(7156);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT || _la==NULL_LITERAL || _la==ERROR) {
					{
					setState(7155);
					jsonOnError();
					}
				}

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

	public static class CaseFuncAlternativeContext extends ParserRuleContext {
		public FunctionArgContext condition;
		public FunctionArgContext consequent;
		public TerminalNode WHEN() { return getToken(MariaDBParser.WHEN, 0); }
		public TerminalNode THEN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCaseFuncAlternative(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCaseFuncAlternative(this);
		}
	}

	public final CaseFuncAlternativeContext caseFuncAlternative() throws RecognitionException {
		CaseFuncAlternativeContext _localctx = new CaseFuncAlternativeContext(_ctx, getState());
		enterRule(_localctx, 662, RULE_caseFuncAlternative);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7162);
			match(WHEN);
			setState(7163);
			((CaseFuncAlternativeContext)_localctx).condition = functionArg();
			setState(7164);
			match(THEN);
			setState(7165);
			((CaseFuncAlternativeContext)_localctx).consequent = functionArg();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class LevelWeightRangeContext extends LevelsInWeightStringContext {
		public DecimalLiteralContext firstLevel;
		public DecimalLiteralContext lastLevel;
		public TerminalNode LEVEL() { return getToken(MariaDBParser.LEVEL, 0); }
		public TerminalNode MINUS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLevelWeightRange(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLevelWeightRange(this);
		}
	}
	public static class LevelWeightListContext extends LevelsInWeightStringContext {
		public TerminalNode LEVEL() { return getToken(MariaDBParser.LEVEL, 0); }
		public List levelInWeightListElement() {
			return getRuleContexts(LevelInWeightListElementContext.class);
		}
		public LevelInWeightListElementContext levelInWeightListElement(int i) {
			return getRuleContext(LevelInWeightListElementContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public LevelWeightListContext(LevelsInWeightStringContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterLevelWeightList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLevelWeightList(this);
		}
	}

	public final LevelsInWeightStringContext levelsInWeightString() throws RecognitionException {
		LevelsInWeightStringContext _localctx = new LevelsInWeightStringContext(_ctx, getState());
		enterRule(_localctx, 664, RULE_levelsInWeightString);
		int _la;
		try {
			setState(7181);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1072,_ctx) ) {
			case 1:
				_localctx = new LevelWeightListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(7167);
				match(LEVEL);
				setState(7168);
				levelInWeightListElement();
				setState(7173);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(7169);
					match(COMMA);
					setState(7170);
					levelInWeightListElement();
					}
					}
					setState(7175);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new LevelWeightRangeContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(7176);
				match(LEVEL);
				setState(7177);
				((LevelWeightRangeContext)_localctx).firstLevel = decimalLiteral();
				setState(7178);
				match(MINUS);
				setState(7179);
				((LevelWeightRangeContext)_localctx).lastLevel = decimalLiteral();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class LevelInWeightListElementContext extends ParserRuleContext {
		public Token orderType;
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode ASC() { return getToken(MariaDBParser.ASC, 0); }
		public TerminalNode DESC() { return getToken(MariaDBParser.DESC, 0); }
		public TerminalNode REVERSE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLevelInWeightListElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLevelInWeightListElement(this);
		}
	}

	public final LevelInWeightListElementContext levelInWeightListElement() throws RecognitionException {
		LevelInWeightListElementContext _localctx = new LevelInWeightListElementContext(_ctx, getState());
		enterRule(_localctx, 666, RULE_levelInWeightListElement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7183);
			decimalLiteral();
			setState(7185);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ASC || _la==DESC || _la==REVERSE) {
				{
				setState(7184);
				((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;
	}

	public static class AggregateWindowedFunctionContext extends ParserRuleContext {
		public Token aggregator;
		public Token starArg;
		public Token separator;
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public FunctionArgContext functionArg() {
			return getRuleContext(FunctionArgContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode AVG() { return getToken(MariaDBParser.AVG, 0); }
		public TerminalNode MAX() { return getToken(MariaDBParser.MAX, 0); }
		public TerminalNode MIN() { return getToken(MariaDBParser.MIN, 0); }
		public TerminalNode SUM() { return getToken(MariaDBParser.SUM, 0); }
		public OverClauseContext overClause() {
			return getRuleContext(OverClauseContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MariaDBParser.DISTINCT, 0); }
		public TerminalNode COUNT() { return getToken(MariaDBParser.COUNT, 0); }
		public FunctionArgsContext functionArgs() {
			return getRuleContext(FunctionArgsContext.class,0);
		}
		public TerminalNode STAR() { return getToken(MariaDBParser.STAR, 0); }
		public TerminalNode BIT_AND() { return getToken(MariaDBParser.BIT_AND, 0); }
		public TerminalNode BIT_OR() { return getToken(MariaDBParser.BIT_OR, 0); }
		public TerminalNode BIT_XOR() { return getToken(MariaDBParser.BIT_XOR, 0); }
		public TerminalNode STD() { return getToken(MariaDBParser.STD, 0); }
		public TerminalNode STDDEV() { return getToken(MariaDBParser.STDDEV, 0); }
		public TerminalNode STDDEV_POP() { return getToken(MariaDBParser.STDDEV_POP, 0); }
		public TerminalNode STDDEV_SAMP() { return getToken(MariaDBParser.STDDEV_SAMP, 0); }
		public TerminalNode VAR_POP() { return getToken(MariaDBParser.VAR_POP, 0); }
		public TerminalNode VAR_SAMP() { return getToken(MariaDBParser.VAR_SAMP, 0); }
		public TerminalNode VARIANCE() { return getToken(MariaDBParser.VARIANCE, 0); }
		public TerminalNode GROUP_CONCAT() { return getToken(MariaDBParser.GROUP_CONCAT, 0); }
		public TerminalNode ORDER() { return getToken(MariaDBParser.ORDER, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public List orderByExpression() {
			return getRuleContexts(OrderByExpressionContext.class);
		}
		public OrderByExpressionContext orderByExpression(int i) {
			return getRuleContext(OrderByExpressionContext.class,i);
		}
		public TerminalNode SEPARATOR() { return getToken(MariaDBParser.SEPARATOR, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterAggregateWindowedFunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitAggregateWindowedFunction(this);
		}
	}

	public final AggregateWindowedFunctionContext aggregateWindowedFunction() throws RecognitionException {
		AggregateWindowedFunctionContext _localctx = new AggregateWindowedFunctionContext(_ctx, getState());
		enterRule(_localctx, 668, RULE_aggregateWindowedFunction);
		int _la;
		try {
			setState(7246);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case AVG:
			case MAX:
			case MIN:
			case SUM:
				enterOuterAlt(_localctx, 1);
				{
				setState(7187);
				_la = _input.LA(1);
				if ( !(((((_la - 286)) & ~0x3f) == 0 && ((1L << (_la - 286)) & ((1L << (AVG - 286)) | (1L << (MAX - 286)) | (1L << (MIN - 286)) | (1L << (SUM - 286)))) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(7188);
				match(LR_BRACKET);
				setState(7190);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1074,_ctx) ) {
				case 1:
					{
					setState(7189);
					((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(7192);
				functionArg();
				setState(7193);
				match(RR_BRACKET);
				setState(7195);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1075,_ctx) ) {
				case 1:
					{
					setState(7194);
					overClause();
					}
					break;
				}
				}
				break;
			case COUNT:
				enterOuterAlt(_localctx, 2);
				{
				setState(7197);
				match(COUNT);
				setState(7198);
				match(LR_BRACKET);
				setState(7206);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1077,_ctx) ) {
				case 1:
					{
					setState(7199);
					((AggregateWindowedFunctionContext)_localctx).starArg = match(STAR);
					}
					break;
				case 2:
					{
					setState(7201);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,1076,_ctx) ) {
					case 1:
						{
						setState(7200);
						((AggregateWindowedFunctionContext)_localctx).aggregator = match(ALL);
						}
						break;
					}
					setState(7203);
					functionArg();
					}
					break;
				case 3:
					{
					setState(7204);
					((AggregateWindowedFunctionContext)_localctx).aggregator = match(DISTINCT);
					setState(7205);
					functionArgs();
					}
					break;
				}
				setState(7208);
				match(RR_BRACKET);
				setState(7210);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1078,_ctx) ) {
				case 1:
					{
					setState(7209);
					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(7212);
				_la = _input.LA(1);
				if ( !(((((_la - 287)) & ~0x3f) == 0 && ((1L << (_la - 287)) & ((1L << (BIT_AND - 287)) | (1L << (BIT_OR - 287)) | (1L << (BIT_XOR - 287)) | (1L << (STD - 287)) | (1L << (STDDEV - 287)) | (1L << (STDDEV_POP - 287)) | (1L << (STDDEV_SAMP - 287)) | (1L << (VAR_POP - 287)) | (1L << (VAR_SAMP - 287)) | (1L << (VARIANCE - 287)))) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(7213);
				match(LR_BRACKET);
				setState(7215);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1079,_ctx) ) {
				case 1:
					{
					setState(7214);
					((AggregateWindowedFunctionContext)_localctx).aggregator = match(ALL);
					}
					break;
				}
				setState(7217);
				functionArg();
				setState(7218);
				match(RR_BRACKET);
				setState(7220);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1080,_ctx) ) {
				case 1:
					{
					setState(7219);
					overClause();
					}
					break;
				}
				}
				break;
			case GROUP_CONCAT:
				enterOuterAlt(_localctx, 4);
				{
				setState(7222);
				match(GROUP_CONCAT);
				setState(7223);
				match(LR_BRACKET);
				setState(7225);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1081,_ctx) ) {
				case 1:
					{
					setState(7224);
					((AggregateWindowedFunctionContext)_localctx).aggregator = match(DISTINCT);
					}
					break;
				}
				setState(7227);
				functionArgs();
				setState(7238);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ORDER) {
					{
					setState(7228);
					match(ORDER);
					setState(7229);
					match(BY);
					setState(7230);
					orderByExpression();
					setState(7235);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(7231);
						match(COMMA);
						setState(7232);
						orderByExpression();
						}
						}
						setState(7237);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				setState(7242);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==SEPARATOR) {
					{
					setState(7240);
					match(SEPARATOR);
					setState(7241);
					((AggregateWindowedFunctionContext)_localctx).separator = match(STRING_LITERAL);
					}
				}

				setState(7244);
				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;
	}

	public static class NonAggregateWindowedFunctionContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public OverClauseContext overClause() {
			return getRuleContext(OverClauseContext.class,0);
		}
		public TerminalNode LAG() { return getToken(MariaDBParser.LAG, 0); }
		public TerminalNode LEAD() { return getToken(MariaDBParser.LEAD, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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(MariaDBParser.FIRST_VALUE, 0); }
		public TerminalNode LAST_VALUE() { return getToken(MariaDBParser.LAST_VALUE, 0); }
		public TerminalNode CUME_DIST() { return getToken(MariaDBParser.CUME_DIST, 0); }
		public TerminalNode DENSE_RANK() { return getToken(MariaDBParser.DENSE_RANK, 0); }
		public TerminalNode PERCENT_RANK() { return getToken(MariaDBParser.PERCENT_RANK, 0); }
		public TerminalNode RANK() { return getToken(MariaDBParser.RANK, 0); }
		public TerminalNode ROW_NUMBER() { return getToken(MariaDBParser.ROW_NUMBER, 0); }
		public TerminalNode NTH_VALUE() { return getToken(MariaDBParser.NTH_VALUE, 0); }
		public TerminalNode NTILE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterNonAggregateWindowedFunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitNonAggregateWindowedFunction(this);
		}
	}

	public final NonAggregateWindowedFunctionContext nonAggregateWindowedFunction() throws RecognitionException {
		NonAggregateWindowedFunctionContext _localctx = new NonAggregateWindowedFunctionContext(_ctx, getState());
		enterRule(_localctx, 670, RULE_nonAggregateWindowedFunction);
		int _la;
		try {
			setState(7286);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LAG:
			case LEAD:
				enterOuterAlt(_localctx, 1);
				{
				setState(7248);
				_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(7249);
				match(LR_BRACKET);
				setState(7250);
				expression(0);
				setState(7253);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1086,_ctx) ) {
				case 1:
					{
					setState(7251);
					match(COMMA);
					setState(7252);
					decimalLiteral();
					}
					break;
				}
				setState(7257);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(7255);
					match(COMMA);
					setState(7256);
					decimalLiteral();
					}
				}

				setState(7259);
				match(RR_BRACKET);
				setState(7260);
				overClause();
				}
				break;
			case FIRST_VALUE:
			case LAST_VALUE:
				enterOuterAlt(_localctx, 2);
				{
				setState(7262);
				_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(7263);
				match(LR_BRACKET);
				setState(7264);
				expression(0);
				setState(7265);
				match(RR_BRACKET);
				setState(7266);
				overClause();
				}
				break;
			case CUME_DIST:
			case DENSE_RANK:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
				enterOuterAlt(_localctx, 3);
				{
				setState(7268);
				_la = _input.LA(1);
				if ( !(((((_la - 291)) & ~0x3f) == 0 && ((1L << (_la - 291)) & ((1L << (CUME_DIST - 291)) | (1L << (DENSE_RANK - 291)) | (1L << (PERCENT_RANK - 291)) | (1L << (RANK - 291)) | (1L << (ROW_NUMBER - 291)))) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(7269);
				match(LR_BRACKET);
				setState(7270);
				match(RR_BRACKET);
				setState(7271);
				overClause();
				}
				break;
			case NTH_VALUE:
				enterOuterAlt(_localctx, 4);
				{
				setState(7272);
				match(NTH_VALUE);
				setState(7273);
				match(LR_BRACKET);
				setState(7274);
				expression(0);
				setState(7275);
				match(COMMA);
				setState(7276);
				decimalLiteral();
				setState(7277);
				match(RR_BRACKET);
				setState(7278);
				overClause();
				}
				break;
			case NTILE:
				enterOuterAlt(_localctx, 5);
				{
				setState(7280);
				match(NTILE);
				setState(7281);
				match(LR_BRACKET);
				setState(7282);
				decimalLiteral();
				setState(7283);
				match(RR_BRACKET);
				setState(7284);
				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;
	}

	public static class OverClauseContext extends ParserRuleContext {
		public TerminalNode OVER() { return getToken(MariaDBParser.OVER, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public WindowNameContext windowName() {
			return getRuleContext(WindowNameContext.class,0);
		}
		public WindowSpecContext windowSpec() {
			return getRuleContext(WindowSpecContext.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterOverClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitOverClause(this);
		}
	}

	public final OverClauseContext overClause() throws RecognitionException {
		OverClauseContext _localctx = new OverClauseContext(_ctx, getState());
		enterRule(_localctx, 672, RULE_overClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7288);
			match(OVER);
			setState(7295);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LR_BRACKET:
				{
				setState(7289);
				match(LR_BRACKET);
				setState(7291);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1089,_ctx) ) {
				case 1:
					{
					setState(7290);
					windowSpec();
					}
					break;
				}
				setState(7293);
				match(RR_BRACKET);
				}
				break;
			case ATTRIBUTE:
			case BODY:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_ROLE:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case LOCKED:
			case MAXVALUE:
			case MINVALUE:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case PACKAGE:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_:
			case STACKED:
			case STATEMENT:
			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 CYCLE:
			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 ENCRYPTED:
			case ENCRYPTION:
			case ENCRYPTION_KEY_ID:
			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 INCREMENT:
			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 LOCALES:
			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 NOCACHE:
			case NOCOPY:
			case NOCYCLE:
			case NOMAXVALUE:
			case NOMINVALUE:
			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 QUERY_RESPONSE_TIME:
			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 RESTART:
			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 SEQUENCE:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLAVES:
			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 TYPES:
			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 WSREP_MEMBERSHIP:
			case WSREP_STATUS:
			case X509:
			case XA:
			case XML:
			case YES:
			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 USER_STATISTICS:
			case CLIENT_STATISTICS:
			case INDEX_STATISTICS:
			case TABLE_STATISTICS:
			case ADMIN:
			case AUDIT_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_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_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 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 VIA:
			case LASTVAL:
			case NEXTVAL:
			case SETVAL:
			case PREVIOUS:
			case PERSISTENT:
			case BINLOG_MONITOR:
			case BINLOG_REPLAY:
			case FEDERATED_ADMIN:
			case READ_ONLY_ADMIN:
			case REPLICA:
			case REPLICAS:
			case REPLICATION_MASTER_ADMIN:
			case MONITOR:
			case READ_ONLY:
			case REPLAY:
			case MOD:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				{
				setState(7294);
				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;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterWindowSpec(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitWindowSpec(this);
		}
	}

	public final WindowSpecContext windowSpec() throws RecognitionException {
		WindowSpecContext _localctx = new WindowSpecContext(_ctx, getState());
		enterRule(_localctx, 674, RULE_windowSpec);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7298);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1091,_ctx) ) {
			case 1:
				{
				setState(7297);
				windowName();
				}
				break;
			}
			setState(7301);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(7300);
				partitionClause();
				}
			}

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

			setState(7307);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==RANGE || _la==ROWS) {
				{
				setState(7306);
				frameClause();
				}
			}

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

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterWindowName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitWindowName(this);
		}
	}

	public final WindowNameContext windowName() throws RecognitionException {
		WindowNameContext _localctx = new WindowNameContext(_ctx, getState());
		enterRule(_localctx, 676, RULE_windowName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7309);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFrameClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFrameClause(this);
		}
	}

	public final FrameClauseContext frameClause() throws RecognitionException {
		FrameClauseContext _localctx = new FrameClauseContext(_ctx, getState());
		enterRule(_localctx, 678, RULE_frameClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7311);
			frameUnits();
			setState(7312);
			frameExtent();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class FrameUnitsContext extends ParserRuleContext {
		public TerminalNode ROWS() { return getToken(MariaDBParser.ROWS, 0); }
		public TerminalNode RANGE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFrameUnits(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFrameUnits(this);
		}
	}

	public final FrameUnitsContext frameUnits() throws RecognitionException {
		FrameUnitsContext _localctx = new FrameUnitsContext(_ctx, getState());
		enterRule(_localctx, 680, RULE_frameUnits);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7314);
			_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;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFrameExtent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFrameExtent(this);
		}
	}

	public final FrameExtentContext frameExtent() throws RecognitionException {
		FrameExtentContext _localctx = new FrameExtentContext(_ctx, getState());
		enterRule(_localctx, 682, RULE_frameExtent);
		try {
			setState(7318);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1095,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(7316);
				frameRange();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(7317);
				frameBetween();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class FrameBetweenContext extends ParserRuleContext {
		public TerminalNode BETWEEN() { return getToken(MariaDBParser.BETWEEN, 0); }
		public List frameRange() {
			return getRuleContexts(FrameRangeContext.class);
		}
		public FrameRangeContext frameRange(int i) {
			return getRuleContext(FrameRangeContext.class,i);
		}
		public TerminalNode AND() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFrameBetween(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFrameBetween(this);
		}
	}

	public final FrameBetweenContext frameBetween() throws RecognitionException {
		FrameBetweenContext _localctx = new FrameBetweenContext(_ctx, getState());
		enterRule(_localctx, 684, RULE_frameBetween);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7320);
			match(BETWEEN);
			setState(7321);
			frameRange();
			setState(7322);
			match(AND);
			setState(7323);
			frameRange();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class FrameRangeContext extends ParserRuleContext {
		public TerminalNode CURRENT() { return getToken(MariaDBParser.CURRENT, 0); }
		public TerminalNode ROW() { return getToken(MariaDBParser.ROW, 0); }
		public TerminalNode UNBOUNDED() { return getToken(MariaDBParser.UNBOUNDED, 0); }
		public TerminalNode PRECEDING() { return getToken(MariaDBParser.PRECEDING, 0); }
		public TerminalNode FOLLOWING() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFrameRange(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFrameRange(this);
		}
	}

	public final FrameRangeContext frameRange() throws RecognitionException {
		FrameRangeContext _localctx = new FrameRangeContext(_ctx, getState());
		enterRule(_localctx, 686, RULE_frameRange);
		int _la;
		try {
			setState(7332);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1096,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(7325);
				match(CURRENT);
				setState(7326);
				match(ROW);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(7327);
				match(UNBOUNDED);
				setState(7328);
				_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(7329);
				expression(0);
				setState(7330);
				_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;
	}

	public static class PartitionClauseContext extends ParserRuleContext {
		public TerminalNode PARTITION() { return getToken(MariaDBParser.PARTITION, 0); }
		public TerminalNode BY() { return getToken(MariaDBParser.BY, 0); }
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPartitionClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPartitionClause(this);
		}
	}

	public final PartitionClauseContext partitionClause() throws RecognitionException {
		PartitionClauseContext _localctx = new PartitionClauseContext(_ctx, getState());
		enterRule(_localctx, 688, RULE_partitionClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7334);
			match(PARTITION);
			setState(7335);
			match(BY);
			setState(7336);
			expression(0);
			setState(7341);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(7337);
				match(COMMA);
				setState(7338);
				expression(0);
				}
				}
				setState(7343);
				_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;
	}

	public static class ScalarFunctionNameContext extends ParserRuleContext {
		public FunctionNameBaseContext functionNameBase() {
			return getRuleContext(FunctionNameBaseContext.class,0);
		}
		public TerminalNode ASCII() { return getToken(MariaDBParser.ASCII, 0); }
		public TerminalNode CURDATE() { return getToken(MariaDBParser.CURDATE, 0); }
		public TerminalNode CURRENT_DATE() { return getToken(MariaDBParser.CURRENT_DATE, 0); }
		public TerminalNode CURRENT_TIME() { return getToken(MariaDBParser.CURRENT_TIME, 0); }
		public TerminalNode CURRENT_TIMESTAMP() { return getToken(MariaDBParser.CURRENT_TIMESTAMP, 0); }
		public TerminalNode CURTIME() { return getToken(MariaDBParser.CURTIME, 0); }
		public TerminalNode DATE_ADD() { return getToken(MariaDBParser.DATE_ADD, 0); }
		public TerminalNode DATE_SUB() { return getToken(MariaDBParser.DATE_SUB, 0); }
		public TerminalNode IF() { return getToken(MariaDBParser.IF, 0); }
		public TerminalNode INSERT() { return getToken(MariaDBParser.INSERT, 0); }
		public TerminalNode LOCALTIME() { return getToken(MariaDBParser.LOCALTIME, 0); }
		public TerminalNode LOCALTIMESTAMP() { return getToken(MariaDBParser.LOCALTIMESTAMP, 0); }
		public TerminalNode MID() { return getToken(MariaDBParser.MID, 0); }
		public TerminalNode NOW() { return getToken(MariaDBParser.NOW, 0); }
		public TerminalNode REPLACE() { return getToken(MariaDBParser.REPLACE, 0); }
		public TerminalNode SUBSTR() { return getToken(MariaDBParser.SUBSTR, 0); }
		public TerminalNode SUBSTRING() { return getToken(MariaDBParser.SUBSTRING, 0); }
		public TerminalNode SYSDATE() { return getToken(MariaDBParser.SYSDATE, 0); }
		public TerminalNode TRIM() { return getToken(MariaDBParser.TRIM, 0); }
		public TerminalNode UTC_DATE() { return getToken(MariaDBParser.UTC_DATE, 0); }
		public TerminalNode UTC_TIME() { return getToken(MariaDBParser.UTC_TIME, 0); }
		public TerminalNode UTC_TIMESTAMP() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterScalarFunctionName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitScalarFunctionName(this);
		}
	}

	public final ScalarFunctionNameContext scalarFunctionName() throws RecognitionException {
		ScalarFunctionNameContext _localctx = new ScalarFunctionNameContext(_ctx, getState());
		enterRule(_localctx, 690, RULE_scalarFunctionName);
		try {
			setState(7367);
			_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_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 LASTVAL:
			case NEXTVAL:
			case SETVAL:
			case MOD:
				enterOuterAlt(_localctx, 1);
				{
				setState(7344);
				functionNameBase();
				}
				break;
			case ASCII:
				enterOuterAlt(_localctx, 2);
				{
				setState(7345);
				match(ASCII);
				}
				break;
			case CURDATE:
				enterOuterAlt(_localctx, 3);
				{
				setState(7346);
				match(CURDATE);
				}
				break;
			case CURRENT_DATE:
				enterOuterAlt(_localctx, 4);
				{
				setState(7347);
				match(CURRENT_DATE);
				}
				break;
			case CURRENT_TIME:
				enterOuterAlt(_localctx, 5);
				{
				setState(7348);
				match(CURRENT_TIME);
				}
				break;
			case CURRENT_TIMESTAMP:
				enterOuterAlt(_localctx, 6);
				{
				setState(7349);
				match(CURRENT_TIMESTAMP);
				}
				break;
			case CURTIME:
				enterOuterAlt(_localctx, 7);
				{
				setState(7350);
				match(CURTIME);
				}
				break;
			case DATE_ADD:
				enterOuterAlt(_localctx, 8);
				{
				setState(7351);
				match(DATE_ADD);
				}
				break;
			case DATE_SUB:
				enterOuterAlt(_localctx, 9);
				{
				setState(7352);
				match(DATE_SUB);
				}
				break;
			case IF:
				enterOuterAlt(_localctx, 10);
				{
				setState(7353);
				match(IF);
				}
				break;
			case INSERT:
				enterOuterAlt(_localctx, 11);
				{
				setState(7354);
				match(INSERT);
				}
				break;
			case LOCALTIME:
				enterOuterAlt(_localctx, 12);
				{
				setState(7355);
				match(LOCALTIME);
				}
				break;
			case LOCALTIMESTAMP:
				enterOuterAlt(_localctx, 13);
				{
				setState(7356);
				match(LOCALTIMESTAMP);
				}
				break;
			case MID:
				enterOuterAlt(_localctx, 14);
				{
				setState(7357);
				match(MID);
				}
				break;
			case NOW:
				enterOuterAlt(_localctx, 15);
				{
				setState(7358);
				match(NOW);
				}
				break;
			case REPLACE:
				enterOuterAlt(_localctx, 16);
				{
				setState(7359);
				match(REPLACE);
				}
				break;
			case SUBSTR:
				enterOuterAlt(_localctx, 17);
				{
				setState(7360);
				match(SUBSTR);
				}
				break;
			case SUBSTRING:
				enterOuterAlt(_localctx, 18);
				{
				setState(7361);
				match(SUBSTRING);
				}
				break;
			case SYSDATE:
				enterOuterAlt(_localctx, 19);
				{
				setState(7362);
				match(SYSDATE);
				}
				break;
			case TRIM:
				enterOuterAlt(_localctx, 20);
				{
				setState(7363);
				match(TRIM);
				}
				break;
			case UTC_DATE:
				enterOuterAlt(_localctx, 21);
				{
				setState(7364);
				match(UTC_DATE);
				}
				break;
			case UTC_TIME:
				enterOuterAlt(_localctx, 22);
				{
				setState(7365);
				match(UTC_TIME);
				}
				break;
			case UTC_TIMESTAMP:
				enterOuterAlt(_localctx, 23);
				{
				setState(7366);
				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;
	}

	public static class PasswordFunctionClauseContext extends ParserRuleContext {
		public Token functionName;
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public FunctionArgContext functionArg() {
			return getRuleContext(FunctionArgContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode PASSWORD() { return getToken(MariaDBParser.PASSWORD, 0); }
		public TerminalNode OLD_PASSWORD() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPasswordFunctionClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPasswordFunctionClause(this);
		}
	}

	public final PasswordFunctionClauseContext passwordFunctionClause() throws RecognitionException {
		PasswordFunctionClauseContext _localctx = new PasswordFunctionClauseContext(_ctx, getState());
		enterRule(_localctx, 692, RULE_passwordFunctionClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7369);
			((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(7370);
			match(LR_BRACKET);
			setState(7371);
			functionArg();
			setState(7372);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFunctionArgs(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFunctionArgs(this);
		}
	}

	public final FunctionArgsContext functionArgs() throws RecognitionException {
		FunctionArgsContext _localctx = new FunctionArgsContext(_ctx, getState());
		enterRule(_localctx, 694, RULE_functionArgs);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7378);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1099,_ctx) ) {
			case 1:
				{
				setState(7374);
				constant();
				}
				break;
			case 2:
				{
				setState(7375);
				fullColumnName();
				}
				break;
			case 3:
				{
				setState(7376);
				functionCall();
				}
				break;
			case 4:
				{
				setState(7377);
				expression(0);
				}
				break;
			}
			setState(7389);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(7380);
				match(COMMA);
				setState(7385);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1100,_ctx) ) {
				case 1:
					{
					setState(7381);
					constant();
					}
					break;
				case 2:
					{
					setState(7382);
					fullColumnName();
					}
					break;
				case 3:
					{
					setState(7383);
					functionCall();
					}
					break;
				case 4:
					{
					setState(7384);
					expression(0);
					}
					break;
				}
				}
				}
				setState(7391);
				_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;
	}

	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFunctionArg(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFunctionArg(this);
		}
	}

	public final FunctionArgContext functionArg() throws RecognitionException {
		FunctionArgContext _localctx = new FunctionArgContext(_ctx, getState());
		enterRule(_localctx, 696, RULE_functionArg);
		try {
			setState(7396);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1102,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(7392);
				constant();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(7393);
				fullColumnName();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(7394);
				functionCall();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(7395);
				expression(0);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	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);
		}
	}
	public static class IsExpressionContext extends ExpressionContext {
		public Token testValue;
		public PredicateContext predicate() {
			return getRuleContext(PredicateContext.class,0);
		}
		public TerminalNode IS() { return getToken(MariaDBParser.IS, 0); }
		public TerminalNode TRUE() { return getToken(MariaDBParser.TRUE, 0); }
		public TerminalNode FALSE() { return getToken(MariaDBParser.FALSE, 0); }
		public TerminalNode UNKNOWN() { return getToken(MariaDBParser.UNKNOWN, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.NOT, 0); }
		public IsExpressionContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterIsExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIsExpression(this);
		}
	}
	public static class NotExpressionContext extends ExpressionContext {
		public Token notOperator;
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode NOT() { return getToken(MariaDBParser.NOT, 0); }
		public TerminalNode EXCLAMATION_SYMBOL() { return getToken(MariaDBParser.EXCLAMATION_SYMBOL, 0); }
		public NotExpressionContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterNotExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitNotExpression(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLogicalExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLogicalExpression(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPredicateExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPredicateExpression(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 = 698;
		enterRecursionRule(_localctx, 698, RULE_expression, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(7409);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1104,_ctx) ) {
			case 1:
				{
				_localctx = new NotExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(7399);
				((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(7400);
				expression(4);
				}
				break;
			case 2:
				{
				_localctx = new IsExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7401);
				predicate(0);
				setState(7402);
				match(IS);
				setState(7404);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(7403);
					match(NOT);
					}
				}

				setState(7406);
				((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(7408);
				predicate(0);
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(7417);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,1105,_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(7411);
					if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
					setState(7412);
					logicalOperator();
					setState(7413);
					expression(4);
					}
					} 
				}
				setState(7419);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1105,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	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);
		}
	}
	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(MariaDBParser.SOUNDS, 0); }
		public TerminalNode LIKE() { return getToken(MariaDBParser.LIKE, 0); }
		public SoundsLikePredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSoundsLikePredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSoundsLikePredicate(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterExpressionAtomPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitExpressionAtomPredicate(this);
		}
	}
	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(MariaDBParser.LR_BRACKET, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public TerminalNode ALL() { return getToken(MariaDBParser.ALL, 0); }
		public TerminalNode ANY() { return getToken(MariaDBParser.ANY, 0); }
		public TerminalNode SOME() { return getToken(MariaDBParser.SOME, 0); }
		public SubqueryComparisonPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSubqueryComparisonPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSubqueryComparisonPredicate(this);
		}
	}
	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(MariaDBParser.MEMBER, 0); }
		public TerminalNode OF() { return getToken(MariaDBParser.OF, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public JsonMemberOfPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterJsonMemberOfPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitJsonMemberOfPredicate(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterBinaryComparisonPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitBinaryComparisonPredicate(this);
		}
	}
	public static class InPredicateContext extends PredicateContext {
		public PredicateContext predicate() {
			return getRuleContext(PredicateContext.class,0);
		}
		public TerminalNode IN() { return getToken(MariaDBParser.IN, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public ExpressionsContext expressions() {
			return getRuleContext(ExpressionsContext.class,0);
		}
		public TerminalNode NOT() { return getToken(MariaDBParser.NOT, 0); }
		public InPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterInPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitInPredicate(this);
		}
	}
	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(MariaDBParser.BETWEEN, 0); }
		public TerminalNode AND() { return getToken(MariaDBParser.AND, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.NOT, 0); }
		public BetweenPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterBetweenPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitBetweenPredicate(this);
		}
	}
	public static class IsNullPredicateContext extends PredicateContext {
		public PredicateContext predicate() {
			return getRuleContext(PredicateContext.class,0);
		}
		public TerminalNode IS() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIsNullPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIsNullPredicate(this);
		}
	}
	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(MariaDBParser.LIKE, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.NOT, 0); }
		public TerminalNode ESCAPE() { return getToken(MariaDBParser.ESCAPE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MariaDBParser.STRING_LITERAL, 0); }
		public LikePredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterLikePredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLikePredicate(this);
		}
	}
	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(MariaDBParser.REGEXP, 0); }
		public TerminalNode RLIKE() { return getToken(MariaDBParser.RLIKE, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.NOT, 0); }
		public RegexpPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterRegexpPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitRegexpPredicate(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 = 700;
		enterRecursionRule(_localctx, 700, RULE_predicate, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			{
			_localctx = new ExpressionAtomPredicateContext(_localctx);
			_ctx = _localctx;
			_prevctx = _localctx;

			setState(7421);
			expressionAtom(0);
			}
			_ctx.stop = _input.LT(-1);
			setState(7487);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,1113,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					setState(7485);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,1112,_ctx) ) {
					case 1:
						{
						_localctx = new BinaryComparisonPredicateContext(new PredicateContext(_parentctx, _parentState));
						((BinaryComparisonPredicateContext)_localctx).left = _prevctx;
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7423);
						if (!(precpred(_ctx, 8))) throw new FailedPredicateException(this, "precpred(_ctx, 8)");
						setState(7424);
						comparisonOperator();
						setState(7425);
						((BinaryComparisonPredicateContext)_localctx).right = predicate(9);
						}
						break;
					case 2:
						{
						_localctx = new BetweenPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7427);
						if (!(precpred(_ctx, 6))) throw new FailedPredicateException(this, "precpred(_ctx, 6)");
						setState(7429);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==NOT) {
							{
							setState(7428);
							match(NOT);
							}
						}

						setState(7431);
						match(BETWEEN);
						setState(7432);
						predicate(0);
						setState(7433);
						match(AND);
						setState(7434);
						predicate(7);
						}
						break;
					case 3:
						{
						_localctx = new SoundsLikePredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7436);
						if (!(precpred(_ctx, 5))) throw new FailedPredicateException(this, "precpred(_ctx, 5)");
						setState(7437);
						match(SOUNDS);
						setState(7438);
						match(LIKE);
						setState(7439);
						predicate(6);
						}
						break;
					case 4:
						{
						_localctx = new RegexpPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7440);
						if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
						setState(7442);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==NOT) {
							{
							setState(7441);
							match(NOT);
							}
						}

						setState(7444);
						((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(7445);
						predicate(4);
						}
						break;
					case 5:
						{
						_localctx = new InPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7446);
						if (!(precpred(_ctx, 10))) throw new FailedPredicateException(this, "precpred(_ctx, 10)");
						setState(7448);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==NOT) {
							{
							setState(7447);
							match(NOT);
							}
						}

						setState(7450);
						match(IN);
						setState(7451);
						match(LR_BRACKET);
						setState(7454);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,1109,_ctx) ) {
						case 1:
							{
							setState(7452);
							selectStatement();
							}
							break;
						case 2:
							{
							setState(7453);
							expressions();
							}
							break;
						}
						setState(7456);
						match(RR_BRACKET);
						}
						break;
					case 6:
						{
						_localctx = new IsNullPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7458);
						if (!(precpred(_ctx, 9))) throw new FailedPredicateException(this, "precpred(_ctx, 9)");
						setState(7459);
						match(IS);
						setState(7460);
						nullNotnull();
						}
						break;
					case 7:
						{
						_localctx = new SubqueryComparisonPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7461);
						if (!(precpred(_ctx, 7))) throw new FailedPredicateException(this, "precpred(_ctx, 7)");
						setState(7462);
						comparisonOperator();
						setState(7463);
						((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(7464);
						match(LR_BRACKET);
						setState(7465);
						selectStatement();
						setState(7466);
						match(RR_BRACKET);
						}
						break;
					case 8:
						{
						_localctx = new LikePredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7468);
						if (!(precpred(_ctx, 4))) throw new FailedPredicateException(this, "precpred(_ctx, 4)");
						setState(7470);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==NOT) {
							{
							setState(7469);
							match(NOT);
							}
						}

						setState(7472);
						match(LIKE);
						setState(7473);
						predicate(0);
						setState(7476);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,1111,_ctx) ) {
						case 1:
							{
							setState(7474);
							match(ESCAPE);
							setState(7475);
							match(STRING_LITERAL);
							}
							break;
						}
						}
						break;
					case 9:
						{
						_localctx = new JsonMemberOfPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7478);
						if (!(precpred(_ctx, 2))) throw new FailedPredicateException(this, "precpred(_ctx, 2)");
						setState(7479);
						match(MEMBER);
						setState(7480);
						match(OF);
						setState(7481);
						match(LR_BRACKET);
						setState(7482);
						predicate(0);
						setState(7483);
						match(RR_BRACKET);
						}
						break;
					}
					} 
				}
				setState(7489);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1113,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	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);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUnaryExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUnaryExpressionAtom(this);
		}
	}
	public static class CollateExpressionAtomContext extends ExpressionAtomContext {
		public ExpressionAtomContext expressionAtom() {
			return getRuleContext(ExpressionAtomContext.class,0);
		}
		public TerminalNode COLLATE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCollateExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCollateExpressionAtom(this);
		}
	}
	public static class VariableAssignExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode LOCAL_ID() { return getToken(MariaDBParser.LOCAL_ID, 0); }
		public TerminalNode VAR_ASSIGN() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterVariableAssignExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitVariableAssignExpressionAtom(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterMysqlVariableExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMysqlVariableExpressionAtom(this);
		}
	}
	public static class NestedExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public NestedExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterNestedExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitNestedExpressionAtom(this);
		}
	}
	public static class NestedRowExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode ROW() { return getToken(MariaDBParser.ROW, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.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(MariaDBParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MariaDBParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MariaDBParser.COMMA, i);
		}
		public NestedRowExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterNestedRowExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitNestedRowExpressionAtom(this);
		}
	}
	public static class MathExpressionAtomContext extends ExpressionAtomContext {
		public ExpressionAtomContext left;
		public ExpressionAtomContext right;
		public MathOperatorContext mathOperator() {
			return getRuleContext(MathOperatorContext.class,0);
		}
		public List expressionAtom() {
			return getRuleContexts(ExpressionAtomContext.class);
		}
		public ExpressionAtomContext expressionAtom(int i) {
			return getRuleContext(ExpressionAtomContext.class,i);
		}
		public MathExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterMathExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMathExpressionAtom(this);
		}
	}
	public static class ExistsExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode EXISTS() { return getToken(MariaDBParser.EXISTS, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public ExistsExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterExistsExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitExistsExpressionAtom(this);
		}
	}
	public static class IntervalExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode INTERVAL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIntervalExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIntervalExpressionAtom(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterJsonExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitJsonExpressionAtom(this);
		}
	}
	public static class SubqueryExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode LR_BRACKET() { return getToken(MariaDBParser.LR_BRACKET, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MariaDBParser.RR_BRACKET, 0); }
		public SubqueryExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterSubqueryExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitSubqueryExpressionAtom(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterConstantExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitConstantExpressionAtom(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFunctionCallExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFunctionCallExpressionAtom(this);
		}
	}
	public static class BinaryExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode BINARY() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterBinaryExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitBinaryExpressionAtom(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFullColumnNameExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFullColumnNameExpressionAtom(this);
		}
	}
	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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterBitExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitBitExpressionAtom(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 = 702;
		enterRecursionRule(_localctx, 702, RULE_expressionAtom, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(7538);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1116,_ctx) ) {
			case 1:
				{
				_localctx = new ConstantExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(7491);
				constant();
				}
				break;
			case 2:
				{
				_localctx = new FullColumnNameExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7492);
				fullColumnName();
				}
				break;
			case 3:
				{
				_localctx = new FunctionCallExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7493);
				functionCall();
				}
				break;
			case 4:
				{
				_localctx = new MysqlVariableExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7494);
				mysqlVariable();
				}
				break;
			case 5:
				{
				_localctx = new UnaryExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7495);
				unaryOperator();
				setState(7496);
				expressionAtom(11);
				}
				break;
			case 6:
				{
				_localctx = new BinaryExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7498);
				match(BINARY);
				setState(7499);
				expressionAtom(10);
				}
				break;
			case 7:
				{
				_localctx = new VariableAssignExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7500);
				match(LOCAL_ID);
				setState(7501);
				match(VAR_ASSIGN);
				setState(7502);
				expressionAtom(9);
				}
				break;
			case 8:
				{
				_localctx = new NestedExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7503);
				match(LR_BRACKET);
				setState(7504);
				expression(0);
				setState(7509);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(7505);
					match(COMMA);
					setState(7506);
					expression(0);
					}
					}
					setState(7511);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(7512);
				match(RR_BRACKET);
				}
				break;
			case 9:
				{
				_localctx = new NestedRowExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7514);
				match(ROW);
				setState(7515);
				match(LR_BRACKET);
				setState(7516);
				expression(0);
				setState(7519); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(7517);
					match(COMMA);
					setState(7518);
					expression(0);
					}
					}
					setState(7521); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==COMMA );
				setState(7523);
				match(RR_BRACKET);
				}
				break;
			case 10:
				{
				_localctx = new ExistsExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7525);
				match(EXISTS);
				setState(7526);
				match(LR_BRACKET);
				setState(7527);
				selectStatement();
				setState(7528);
				match(RR_BRACKET);
				}
				break;
			case 11:
				{
				_localctx = new SubqueryExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7530);
				match(LR_BRACKET);
				setState(7531);
				selectStatement();
				setState(7532);
				match(RR_BRACKET);
				}
				break;
			case 12:
				{
				_localctx = new IntervalExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7534);
				match(INTERVAL);
				setState(7535);
				expression(0);
				setState(7536);
				intervalType();
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(7557);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,1118,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					setState(7555);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,1117,_ctx) ) {
					case 1:
						{
						_localctx = new BitExpressionAtomContext(new ExpressionAtomContext(_parentctx, _parentState));
						((BitExpressionAtomContext)_localctx).left = _prevctx;
						pushNewRecursionContext(_localctx, _startState, RULE_expressionAtom);
						setState(7540);
						if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
						setState(7541);
						bitOperator();
						setState(7542);
						((BitExpressionAtomContext)_localctx).right = expressionAtom(4);
						}
						break;
					case 2:
						{
						_localctx = new MathExpressionAtomContext(new ExpressionAtomContext(_parentctx, _parentState));
						((MathExpressionAtomContext)_localctx).left = _prevctx;
						pushNewRecursionContext(_localctx, _startState, RULE_expressionAtom);
						setState(7544);
						if (!(precpred(_ctx, 2))) throw new FailedPredicateException(this, "precpred(_ctx, 2)");
						setState(7545);
						mathOperator();
						setState(7546);
						((MathExpressionAtomContext)_localctx).right = expressionAtom(3);
						}
						break;
					case 3:
						{
						_localctx = new JsonExpressionAtomContext(new ExpressionAtomContext(_parentctx, _parentState));
						((JsonExpressionAtomContext)_localctx).left = _prevctx;
						pushNewRecursionContext(_localctx, _startState, RULE_expressionAtom);
						setState(7548);
						if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
						setState(7549);
						jsonOperator();
						setState(7550);
						((JsonExpressionAtomContext)_localctx).right = expressionAtom(2);
						}
						break;
					case 4:
						{
						_localctx = new CollateExpressionAtomContext(new ExpressionAtomContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expressionAtom);
						setState(7552);
						if (!(precpred(_ctx, 13))) throw new FailedPredicateException(this, "precpred(_ctx, 13)");
						setState(7553);
						match(COLLATE);
						setState(7554);
						collationName();
						}
						break;
					}
					} 
				}
				setState(7559);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1118,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	public static class UnaryOperatorContext extends ParserRuleContext {
		public TerminalNode EXCLAMATION_SYMBOL() { return getToken(MariaDBParser.EXCLAMATION_SYMBOL, 0); }
		public TerminalNode BIT_NOT_OP() { return getToken(MariaDBParser.BIT_NOT_OP, 0); }
		public TerminalNode PLUS() { return getToken(MariaDBParser.PLUS, 0); }
		public TerminalNode MINUS() { return getToken(MariaDBParser.MINUS, 0); }
		public TerminalNode NOT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterUnaryOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitUnaryOperator(this);
		}
	}

	public final UnaryOperatorContext unaryOperator() throws RecognitionException {
		UnaryOperatorContext _localctx = new UnaryOperatorContext(_ctx, getState());
		enterRule(_localctx, 704, RULE_unaryOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7560);
			_la = _input.LA(1);
			if ( !(_la==NOT || ((((_la - 1141)) & ~0x3f) == 0 && ((1L << (_la - 1141)) & ((1L << (PLUS - 1141)) | (1L << (MINUS - 1141)) | (1L << (EXCLAMATION_SYMBOL - 1141)) | (1L << (BIT_NOT_OP - 1141)))) != 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;
	}

	public static class ComparisonOperatorContext extends ParserRuleContext {
		public TerminalNode EQUAL_SYMBOL() { return getToken(MariaDBParser.EQUAL_SYMBOL, 0); }
		public TerminalNode GREATER_SYMBOL() { return getToken(MariaDBParser.GREATER_SYMBOL, 0); }
		public TerminalNode LESS_SYMBOL() { return getToken(MariaDBParser.LESS_SYMBOL, 0); }
		public TerminalNode EXCLAMATION_SYMBOL() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterComparisonOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitComparisonOperator(this);
		}
	}

	public final ComparisonOperatorContext comparisonOperator() throws RecognitionException {
		ComparisonOperatorContext _localctx = new ComparisonOperatorContext(_ctx, getState());
		enterRule(_localctx, 706, RULE_comparisonOperator);
		try {
			setState(7576);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1119,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(7562);
				match(EQUAL_SYMBOL);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(7563);
				match(GREATER_SYMBOL);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(7564);
				match(LESS_SYMBOL);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(7565);
				match(LESS_SYMBOL);
				setState(7566);
				match(EQUAL_SYMBOL);
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(7567);
				match(GREATER_SYMBOL);
				setState(7568);
				match(EQUAL_SYMBOL);
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(7569);
				match(LESS_SYMBOL);
				setState(7570);
				match(GREATER_SYMBOL);
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(7571);
				match(EXCLAMATION_SYMBOL);
				setState(7572);
				match(EQUAL_SYMBOL);
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(7573);
				match(LESS_SYMBOL);
				setState(7574);
				match(EQUAL_SYMBOL);
				setState(7575);
				match(GREATER_SYMBOL);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class LogicalOperatorContext extends ParserRuleContext {
		public TerminalNode AND() { return getToken(MariaDBParser.AND, 0); }
		public List BIT_AND_OP() { return getTokens(MariaDBParser.BIT_AND_OP); }
		public TerminalNode BIT_AND_OP(int i) {
			return getToken(MariaDBParser.BIT_AND_OP, i);
		}
		public TerminalNode XOR() { return getToken(MariaDBParser.XOR, 0); }
		public TerminalNode OR() { return getToken(MariaDBParser.OR, 0); }
		public List BIT_OR_OP() { return getTokens(MariaDBParser.BIT_OR_OP); }
		public TerminalNode BIT_OR_OP(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterLogicalOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitLogicalOperator(this);
		}
	}

	public final LogicalOperatorContext logicalOperator() throws RecognitionException {
		LogicalOperatorContext _localctx = new LogicalOperatorContext(_ctx, getState());
		enterRule(_localctx, 708, RULE_logicalOperator);
		try {
			setState(7585);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case AND:
				enterOuterAlt(_localctx, 1);
				{
				setState(7578);
				match(AND);
				}
				break;
			case BIT_AND_OP:
				enterOuterAlt(_localctx, 2);
				{
				setState(7579);
				match(BIT_AND_OP);
				setState(7580);
				match(BIT_AND_OP);
				}
				break;
			case XOR:
				enterOuterAlt(_localctx, 3);
				{
				setState(7581);
				match(XOR);
				}
				break;
			case OR:
				enterOuterAlt(_localctx, 4);
				{
				setState(7582);
				match(OR);
				}
				break;
			case BIT_OR_OP:
				enterOuterAlt(_localctx, 5);
				{
				setState(7583);
				match(BIT_OR_OP);
				setState(7584);
				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;
	}

	public static class BitOperatorContext extends ParserRuleContext {
		public List LESS_SYMBOL() { return getTokens(MariaDBParser.LESS_SYMBOL); }
		public TerminalNode LESS_SYMBOL(int i) {
			return getToken(MariaDBParser.LESS_SYMBOL, i);
		}
		public List GREATER_SYMBOL() { return getTokens(MariaDBParser.GREATER_SYMBOL); }
		public TerminalNode GREATER_SYMBOL(int i) {
			return getToken(MariaDBParser.GREATER_SYMBOL, i);
		}
		public TerminalNode BIT_AND_OP() { return getToken(MariaDBParser.BIT_AND_OP, 0); }
		public TerminalNode BIT_XOR_OP() { return getToken(MariaDBParser.BIT_XOR_OP, 0); }
		public TerminalNode BIT_OR_OP() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterBitOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitBitOperator(this);
		}
	}

	public final BitOperatorContext bitOperator() throws RecognitionException {
		BitOperatorContext _localctx = new BitOperatorContext(_ctx, getState());
		enterRule(_localctx, 710, RULE_bitOperator);
		try {
			setState(7594);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LESS_SYMBOL:
				enterOuterAlt(_localctx, 1);
				{
				setState(7587);
				match(LESS_SYMBOL);
				setState(7588);
				match(LESS_SYMBOL);
				}
				break;
			case GREATER_SYMBOL:
				enterOuterAlt(_localctx, 2);
				{
				setState(7589);
				match(GREATER_SYMBOL);
				setState(7590);
				match(GREATER_SYMBOL);
				}
				break;
			case BIT_AND_OP:
				enterOuterAlt(_localctx, 3);
				{
				setState(7591);
				match(BIT_AND_OP);
				}
				break;
			case BIT_XOR_OP:
				enterOuterAlt(_localctx, 4);
				{
				setState(7592);
				match(BIT_XOR_OP);
				}
				break;
			case BIT_OR_OP:
				enterOuterAlt(_localctx, 5);
				{
				setState(7593);
				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;
	}

	public static class MathOperatorContext extends ParserRuleContext {
		public TerminalNode STAR() { return getToken(MariaDBParser.STAR, 0); }
		public TerminalNode DIVIDE() { return getToken(MariaDBParser.DIVIDE, 0); }
		public TerminalNode MODULE() { return getToken(MariaDBParser.MODULE, 0); }
		public TerminalNode DIV() { return getToken(MariaDBParser.DIV, 0); }
		public TerminalNode MOD() { return getToken(MariaDBParser.MOD, 0); }
		public TerminalNode PLUS() { return getToken(MariaDBParser.PLUS, 0); }
		public TerminalNode MINUS() { return getToken(MariaDBParser.MINUS, 0); }
		public MathOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_mathOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).enterMathOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitMathOperator(this);
		}
	}

	public final MathOperatorContext mathOperator() throws RecognitionException {
		MathOperatorContext _localctx = new MathOperatorContext(_ctx, getState());
		enterRule(_localctx, 712, RULE_mathOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7596);
			_la = _input.LA(1);
			if ( !(((((_la - 1138)) & ~0x3f) == 0 && ((1L << (_la - 1138)) & ((1L << (STAR - 1138)) | (1L << (DIVIDE - 1138)) | (1L << (MODULE - 1138)) | (1L << (PLUS - 1138)) | (1L << (MINUS - 1138)) | (1L << (DIV - 1138)) | (1L << (MOD - 1138)))) != 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;
	}

	public static class JsonOperatorContext extends ParserRuleContext {
		public TerminalNode MINUS() { return getToken(MariaDBParser.MINUS, 0); }
		public List GREATER_SYMBOL() { return getTokens(MariaDBParser.GREATER_SYMBOL); }
		public TerminalNode GREATER_SYMBOL(int i) {
			return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterJsonOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitJsonOperator(this);
		}
	}

	public final JsonOperatorContext jsonOperator() throws RecognitionException {
		JsonOperatorContext _localctx = new JsonOperatorContext(_ctx, getState());
		enterRule(_localctx, 714, RULE_jsonOperator);
		try {
			setState(7603);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1122,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(7598);
				match(MINUS);
				setState(7599);
				match(GREATER_SYMBOL);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(7600);
				match(MINUS);
				setState(7601);
				match(GREATER_SYMBOL);
				setState(7602);
				match(GREATER_SYMBOL);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public static class CharsetNameBaseContext extends ParserRuleContext {
		public TerminalNode ARMSCII8() { return getToken(MariaDBParser.ARMSCII8, 0); }
		public TerminalNode ASCII() { return getToken(MariaDBParser.ASCII, 0); }
		public TerminalNode BIG5() { return getToken(MariaDBParser.BIG5, 0); }
		public TerminalNode BINARY() { return getToken(MariaDBParser.BINARY, 0); }
		public TerminalNode CP1250() { return getToken(MariaDBParser.CP1250, 0); }
		public TerminalNode CP1251() { return getToken(MariaDBParser.CP1251, 0); }
		public TerminalNode CP1256() { return getToken(MariaDBParser.CP1256, 0); }
		public TerminalNode CP1257() { return getToken(MariaDBParser.CP1257, 0); }
		public TerminalNode CP850() { return getToken(MariaDBParser.CP850, 0); }
		public TerminalNode CP852() { return getToken(MariaDBParser.CP852, 0); }
		public TerminalNode CP866() { return getToken(MariaDBParser.CP866, 0); }
		public TerminalNode CP932() { return getToken(MariaDBParser.CP932, 0); }
		public TerminalNode DEC8() { return getToken(MariaDBParser.DEC8, 0); }
		public TerminalNode EUCJPMS() { return getToken(MariaDBParser.EUCJPMS, 0); }
		public TerminalNode EUCKR() { return getToken(MariaDBParser.EUCKR, 0); }
		public TerminalNode GB18030() { return getToken(MariaDBParser.GB18030, 0); }
		public TerminalNode GB2312() { return getToken(MariaDBParser.GB2312, 0); }
		public TerminalNode GBK() { return getToken(MariaDBParser.GBK, 0); }
		public TerminalNode GEOSTD8() { return getToken(MariaDBParser.GEOSTD8, 0); }
		public TerminalNode GREEK() { return getToken(MariaDBParser.GREEK, 0); }
		public TerminalNode HEBREW() { return getToken(MariaDBParser.HEBREW, 0); }
		public TerminalNode HP8() { return getToken(MariaDBParser.HP8, 0); }
		public TerminalNode KEYBCS2() { return getToken(MariaDBParser.KEYBCS2, 0); }
		public TerminalNode KOI8R() { return getToken(MariaDBParser.KOI8R, 0); }
		public TerminalNode KOI8U() { return getToken(MariaDBParser.KOI8U, 0); }
		public TerminalNode LATIN1() { return getToken(MariaDBParser.LATIN1, 0); }
		public TerminalNode LATIN2() { return getToken(MariaDBParser.LATIN2, 0); }
		public TerminalNode LATIN5() { return getToken(MariaDBParser.LATIN5, 0); }
		public TerminalNode LATIN7() { return getToken(MariaDBParser.LATIN7, 0); }
		public TerminalNode MACCE() { return getToken(MariaDBParser.MACCE, 0); }
		public TerminalNode MACROMAN() { return getToken(MariaDBParser.MACROMAN, 0); }
		public TerminalNode SJIS() { return getToken(MariaDBParser.SJIS, 0); }
		public TerminalNode SWE7() { return getToken(MariaDBParser.SWE7, 0); }
		public TerminalNode TIS620() { return getToken(MariaDBParser.TIS620, 0); }
		public TerminalNode UCS2() { return getToken(MariaDBParser.UCS2, 0); }
		public TerminalNode UJIS() { return getToken(MariaDBParser.UJIS, 0); }
		public TerminalNode UTF16() { return getToken(MariaDBParser.UTF16, 0); }
		public TerminalNode UTF16LE() { return getToken(MariaDBParser.UTF16LE, 0); }
		public TerminalNode UTF32() { return getToken(MariaDBParser.UTF32, 0); }
		public TerminalNode UTF8() { return getToken(MariaDBParser.UTF8, 0); }
		public TerminalNode UTF8MB3() { return getToken(MariaDBParser.UTF8MB3, 0); }
		public TerminalNode UTF8MB4() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterCharsetNameBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitCharsetNameBase(this);
		}
	}

	public final CharsetNameBaseContext charsetNameBase() throws RecognitionException {
		CharsetNameBaseContext _localctx = new CharsetNameBaseContext(_ctx, getState());
		enterRule(_localctx, 716, RULE_charsetNameBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7605);
			_la = _input.LA(1);
			if ( !(_la==BINARY || ((((_la - 753)) & ~0x3f) == 0 && ((1L << (_la - 753)) & ((1L << (ARMSCII8 - 753)) | (1L << (ASCII - 753)) | (1L << (BIG5 - 753)) | (1L << (CP1250 - 753)) | (1L << (CP1251 - 753)) | (1L << (CP1256 - 753)) | (1L << (CP1257 - 753)) | (1L << (CP850 - 753)) | (1L << (CP852 - 753)) | (1L << (CP866 - 753)) | (1L << (CP932 - 753)) | (1L << (DEC8 - 753)) | (1L << (EUCJPMS - 753)) | (1L << (EUCKR - 753)) | (1L << (GB18030 - 753)) | (1L << (GB2312 - 753)) | (1L << (GBK - 753)) | (1L << (GEOSTD8 - 753)) | (1L << (GREEK - 753)) | (1L << (HEBREW - 753)) | (1L << (HP8 - 753)) | (1L << (KEYBCS2 - 753)) | (1L << (KOI8R - 753)) | (1L << (KOI8U - 753)) | (1L << (LATIN1 - 753)) | (1L << (LATIN2 - 753)) | (1L << (LATIN5 - 753)) | (1L << (LATIN7 - 753)) | (1L << (MACCE - 753)) | (1L << (MACROMAN - 753)) | (1L << (SJIS - 753)) | (1L << (SWE7 - 753)) | (1L << (TIS620 - 753)) | (1L << (UCS2 - 753)) | (1L << (UJIS - 753)) | (1L << (UTF16 - 753)) | (1L << (UTF16LE - 753)) | (1L << (UTF32 - 753)) | (1L << (UTF8 - 753)) | (1L << (UTF8MB3 - 753)) | (1L << (UTF8MB4 - 753)))) != 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;
	}

	public static class TransactionLevelBaseContext extends ParserRuleContext {
		public TerminalNode REPEATABLE() { return getToken(MariaDBParser.REPEATABLE, 0); }
		public TerminalNode COMMITTED() { return getToken(MariaDBParser.COMMITTED, 0); }
		public TerminalNode UNCOMMITTED() { return getToken(MariaDBParser.UNCOMMITTED, 0); }
		public TerminalNode SERIALIZABLE() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterTransactionLevelBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitTransactionLevelBase(this);
		}
	}

	public final TransactionLevelBaseContext transactionLevelBase() throws RecognitionException {
		TransactionLevelBaseContext _localctx = new TransactionLevelBaseContext(_ctx, getState());
		enterRule(_localctx, 718, RULE_transactionLevelBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7607);
			_la = _input.LA(1);
			if ( !(((((_la - 806)) & ~0x3f) == 0 && ((1L << (_la - 806)) & ((1L << (REPEATABLE - 806)) | (1L << (COMMITTED - 806)) | (1L << (UNCOMMITTED - 806)) | (1L << (SERIALIZABLE - 806)))) != 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;
	}

	public static class PrivilegesBaseContext extends ParserRuleContext {
		public TerminalNode TABLES() { return getToken(MariaDBParser.TABLES, 0); }
		public TerminalNode ROUTINE() { return getToken(MariaDBParser.ROUTINE, 0); }
		public TerminalNode EXECUTE() { return getToken(MariaDBParser.EXECUTE, 0); }
		public TerminalNode FILE() { return getToken(MariaDBParser.FILE, 0); }
		public TerminalNode PROCESS() { return getToken(MariaDBParser.PROCESS, 0); }
		public TerminalNode RELOAD() { return getToken(MariaDBParser.RELOAD, 0); }
		public TerminalNode SHUTDOWN() { return getToken(MariaDBParser.SHUTDOWN, 0); }
		public TerminalNode SUPER() { return getToken(MariaDBParser.SUPER, 0); }
		public TerminalNode PRIVILEGES() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterPrivilegesBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitPrivilegesBase(this);
		}
	}

	public final PrivilegesBaseContext privilegesBase() throws RecognitionException {
		PrivilegesBaseContext _localctx = new PrivilegesBaseContext(_ctx, getState());
		enterRule(_localctx, 720, RULE_privilegesBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7609);
			_la = _input.LA(1);
			if ( !(((((_la - 716)) & ~0x3f) == 0 && ((1L << (_la - 716)) & ((1L << (EXECUTE - 716)) | (1L << (FILE - 716)) | (1L << (PRIVILEGES - 716)) | (1L << (PROCESS - 716)) | (1L << (RELOAD - 716)) | (1L << (ROUTINE - 716)) | (1L << (SHUTDOWN - 716)) | (1L << (SUPER - 716)) | (1L << (TABLES - 716)))) != 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;
	}

	public static class IntervalTypeBaseContext extends ParserRuleContext {
		public TerminalNode QUARTER() { return getToken(MariaDBParser.QUARTER, 0); }
		public TerminalNode MONTH() { return getToken(MariaDBParser.MONTH, 0); }
		public TerminalNode DAY() { return getToken(MariaDBParser.DAY, 0); }
		public TerminalNode HOUR() { return getToken(MariaDBParser.HOUR, 0); }
		public TerminalNode MINUTE() { return getToken(MariaDBParser.MINUTE, 0); }
		public TerminalNode WEEK() { return getToken(MariaDBParser.WEEK, 0); }
		public TerminalNode SECOND() { return getToken(MariaDBParser.SECOND, 0); }
		public TerminalNode MICROSECOND() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterIntervalTypeBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitIntervalTypeBase(this);
		}
	}

	public final IntervalTypeBaseContext intervalTypeBase() throws RecognitionException {
		IntervalTypeBaseContext _localctx = new IntervalTypeBaseContext(_ctx, getState());
		enterRule(_localctx, 722, RULE_intervalTypeBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7611);
			_la = _input.LA(1);
			if ( !(((((_la - 695)) & ~0x3f) == 0 && ((1L << (_la - 695)) & ((1L << (QUARTER - 695)) | (1L << (MONTH - 695)) | (1L << (DAY - 695)) | (1L << (HOUR - 695)) | (1L << (MINUTE - 695)) | (1L << (WEEK - 695)) | (1L << (SECOND - 695)) | (1L << (MICROSECOND - 695)))) != 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;
	}

	public static class DataTypeBaseContext extends ParserRuleContext {
		public TerminalNode DATE() { return getToken(MariaDBParser.DATE, 0); }
		public TerminalNode TIME() { return getToken(MariaDBParser.TIME, 0); }
		public TerminalNode TIMESTAMP() { return getToken(MariaDBParser.TIMESTAMP, 0); }
		public TerminalNode DATETIME() { return getToken(MariaDBParser.DATETIME, 0); }
		public TerminalNode YEAR() { return getToken(MariaDBParser.YEAR, 0); }
		public TerminalNode ENUM() { return getToken(MariaDBParser.ENUM, 0); }
		public TerminalNode TEXT() { return getToken(MariaDBParser.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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterDataTypeBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitDataTypeBase(this);
		}
	}

	public final DataTypeBaseContext dataTypeBase() throws RecognitionException {
		DataTypeBaseContext _localctx = new DataTypeBaseContext(_ctx, getState());
		enterRule(_localctx, 724, RULE_dataTypeBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7613);
			_la = _input.LA(1);
			if ( !(((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & ((1L << (DATE - 217)) | (1L << (TIME - 217)) | (1L << (TIMESTAMP - 217)) | (1L << (DATETIME - 217)) | (1L << (YEAR - 217)) | (1L << (TEXT - 217)) | (1L << (ENUM - 217)))) != 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;
	}

	public static class KeywordsCanBeIdContext extends ParserRuleContext {
		public TerminalNode ACCOUNT() { return getToken(MariaDBParser.ACCOUNT, 0); }
		public TerminalNode ACTION() { return getToken(MariaDBParser.ACTION, 0); }
		public TerminalNode ADMIN() { return getToken(MariaDBParser.ADMIN, 0); }
		public TerminalNode AFTER() { return getToken(MariaDBParser.AFTER, 0); }
		public TerminalNode AGGREGATE() { return getToken(MariaDBParser.AGGREGATE, 0); }
		public TerminalNode ALGORITHM() { return getToken(MariaDBParser.ALGORITHM, 0); }
		public TerminalNode ANY() { return getToken(MariaDBParser.ANY, 0); }
		public TerminalNode AT() { return getToken(MariaDBParser.AT, 0); }
		public TerminalNode AUDIT_ADMIN() { return getToken(MariaDBParser.AUDIT_ADMIN, 0); }
		public TerminalNode AUTHORS() { return getToken(MariaDBParser.AUTHORS, 0); }
		public TerminalNode AUTOCOMMIT() { return getToken(MariaDBParser.AUTOCOMMIT, 0); }
		public TerminalNode AUTOEXTEND_SIZE() { return getToken(MariaDBParser.AUTOEXTEND_SIZE, 0); }
		public TerminalNode AUTO_INCREMENT() { return getToken(MariaDBParser.AUTO_INCREMENT, 0); }
		public TerminalNode AVG() { return getToken(MariaDBParser.AVG, 0); }
		public TerminalNode AVG_ROW_LENGTH() { return getToken(MariaDBParser.AVG_ROW_LENGTH, 0); }
		public TerminalNode ATTRIBUTE() { return getToken(MariaDBParser.ATTRIBUTE, 0); }
		public TerminalNode BACKUP_ADMIN() { return getToken(MariaDBParser.BACKUP_ADMIN, 0); }
		public TerminalNode BEGIN() { return getToken(MariaDBParser.BEGIN, 0); }
		public TerminalNode BINLOG() { return getToken(MariaDBParser.BINLOG, 0); }
		public TerminalNode BINLOG_ADMIN() { return getToken(MariaDBParser.BINLOG_ADMIN, 0); }
		public TerminalNode BINLOG_ENCRYPTION_ADMIN() { return getToken(MariaDBParser.BINLOG_ENCRYPTION_ADMIN, 0); }
		public TerminalNode BIT() { return getToken(MariaDBParser.BIT, 0); }
		public TerminalNode BIT_AND() { return getToken(MariaDBParser.BIT_AND, 0); }
		public TerminalNode BIT_OR() { return getToken(MariaDBParser.BIT_OR, 0); }
		public TerminalNode BIT_XOR() { return getToken(MariaDBParser.BIT_XOR, 0); }
		public TerminalNode BLOCK() { return getToken(MariaDBParser.BLOCK, 0); }
		public TerminalNode BODY() { return getToken(MariaDBParser.BODY, 0); }
		public TerminalNode BOOL() { return getToken(MariaDBParser.BOOL, 0); }
		public TerminalNode BOOLEAN() { return getToken(MariaDBParser.BOOLEAN, 0); }
		public TerminalNode BTREE() { return getToken(MariaDBParser.BTREE, 0); }
		public TerminalNode BUCKETS() { return getToken(MariaDBParser.BUCKETS, 0); }
		public TerminalNode CACHE() { return getToken(MariaDBParser.CACHE, 0); }
		public TerminalNode CASCADED() { return getToken(MariaDBParser.CASCADED, 0); }
		public TerminalNode CHAIN() { return getToken(MariaDBParser.CHAIN, 0); }
		public TerminalNode CHANGED() { return getToken(MariaDBParser.CHANGED, 0); }
		public TerminalNode CHANNEL() { return getToken(MariaDBParser.CHANNEL, 0); }
		public TerminalNode CHECKSUM() { return getToken(MariaDBParser.CHECKSUM, 0); }
		public TerminalNode PAGE_CHECKSUM() { return getToken(MariaDBParser.PAGE_CHECKSUM, 0); }
		public TerminalNode CATALOG_NAME() { return getToken(MariaDBParser.CATALOG_NAME, 0); }
		public TerminalNode CIPHER() { return getToken(MariaDBParser.CIPHER, 0); }
		public TerminalNode CLASS_ORIGIN() { return getToken(MariaDBParser.CLASS_ORIGIN, 0); }
		public TerminalNode CLIENT() { return getToken(MariaDBParser.CLIENT, 0); }
		public TerminalNode CLONE_ADMIN() { return getToken(MariaDBParser.CLONE_ADMIN, 0); }
		public TerminalNode CLOSE() { return getToken(MariaDBParser.CLOSE, 0); }
		public TerminalNode CLUSTERING() { return getToken(MariaDBParser.CLUSTERING, 0); }
		public TerminalNode COALESCE() { return getToken(MariaDBParser.COALESCE, 0); }
		public TerminalNode CODE() { return getToken(MariaDBParser.CODE, 0); }
		public TerminalNode COLUMNS() { return getToken(MariaDBParser.COLUMNS, 0); }
		public TerminalNode COLUMN_FORMAT() { return getToken(MariaDBParser.COLUMN_FORMAT, 0); }
		public TerminalNode COLUMN_NAME() { return getToken(MariaDBParser.COLUMN_NAME, 0); }
		public TerminalNode COMMENT() { return getToken(MariaDBParser.COMMENT, 0); }
		public TerminalNode COMMIT() { return getToken(MariaDBParser.COMMIT, 0); }
		public TerminalNode COMPACT() { return getToken(MariaDBParser.COMPACT, 0); }
		public TerminalNode COMPLETION() { return getToken(MariaDBParser.COMPLETION, 0); }
		public TerminalNode COMPRESSED() { return getToken(MariaDBParser.COMPRESSED, 0); }
		public TerminalNode COMPRESSION() { return getToken(MariaDBParser.COMPRESSION, 0); }
		public TerminalNode CONCURRENT() { return getToken(MariaDBParser.CONCURRENT, 0); }
		public TerminalNode CONDITION() { return getToken(MariaDBParser.CONDITION, 0); }
		public TerminalNode CONNECT() { return getToken(MariaDBParser.CONNECT, 0); }
		public TerminalNode CONNECTION() { return getToken(MariaDBParser.CONNECTION, 0); }
		public TerminalNode CONNECTION_ADMIN() { return getToken(MariaDBParser.CONNECTION_ADMIN, 0); }
		public TerminalNode CONSISTENT() { return getToken(MariaDBParser.CONSISTENT, 0); }
		public TerminalNode CONSTRAINT_CATALOG() { return getToken(MariaDBParser.CONSTRAINT_CATALOG, 0); }
		public TerminalNode CONSTRAINT_NAME() { return getToken(MariaDBParser.CONSTRAINT_NAME, 0); }
		public TerminalNode CONSTRAINT_SCHEMA() { return getToken(MariaDBParser.CONSTRAINT_SCHEMA, 0); }
		public TerminalNode CONTAINS() { return getToken(MariaDBParser.CONTAINS, 0); }
		public TerminalNode CONTEXT() { return getToken(MariaDBParser.CONTEXT, 0); }
		public TerminalNode CONTRIBUTORS() { return getToken(MariaDBParser.CONTRIBUTORS, 0); }
		public TerminalNode COPY() { return getToken(MariaDBParser.COPY, 0); }
		public TerminalNode COUNT() { return getToken(MariaDBParser.COUNT, 0); }
		public TerminalNode CPU() { return getToken(MariaDBParser.CPU, 0); }
		public TerminalNode CURRENT() { return getToken(MariaDBParser.CURRENT, 0); }
		public TerminalNode CURRENT_USER() { return getToken(MariaDBParser.CURRENT_USER, 0); }
		public TerminalNode CURSOR_NAME() { return getToken(MariaDBParser.CURSOR_NAME, 0); }
		public TerminalNode DATA() { return getToken(MariaDBParser.DATA, 0); }
		public TerminalNode DATAFILE() { return getToken(MariaDBParser.DATAFILE, 0); }
		public TerminalNode DEALLOCATE() { return getToken(MariaDBParser.DEALLOCATE, 0); }
		public TerminalNode DEFAULT() { return getToken(MariaDBParser.DEFAULT, 0); }
		public TerminalNode DEFAULT_AUTH() { return getToken(MariaDBParser.DEFAULT_AUTH, 0); }
		public TerminalNode DEFINER() { return getToken(MariaDBParser.DEFINER, 0); }
		public TerminalNode DELAY_KEY_WRITE() { return getToken(MariaDBParser.DELAY_KEY_WRITE, 0); }
		public TerminalNode DES_KEY_FILE() { return getToken(MariaDBParser.DES_KEY_FILE, 0); }
		public TerminalNode DIAGNOSTICS() { return getToken(MariaDBParser.DIAGNOSTICS, 0); }
		public TerminalNode DIRECTORY() { return getToken(MariaDBParser.DIRECTORY, 0); }
		public TerminalNode DISABLE() { return getToken(MariaDBParser.DISABLE, 0); }
		public TerminalNode DISCARD() { return getToken(MariaDBParser.DISCARD, 0); }
		public TerminalNode DISK() { return getToken(MariaDBParser.DISK, 0); }
		public TerminalNode DO() { return getToken(MariaDBParser.DO, 0); }
		public TerminalNode DUMPFILE() { return getToken(MariaDBParser.DUMPFILE, 0); }
		public TerminalNode DUPLICATE() { return getToken(MariaDBParser.DUPLICATE, 0); }
		public TerminalNode DYNAMIC() { return getToken(MariaDBParser.DYNAMIC, 0); }
		public TerminalNode EMPTY() { return getToken(MariaDBParser.EMPTY, 0); }
		public TerminalNode ENABLE() { return getToken(MariaDBParser.ENABLE, 0); }
		public TerminalNode ENCRYPTION() { return getToken(MariaDBParser.ENCRYPTION, 0); }
		public TerminalNode ENCRYPTION_KEY_ADMIN() { return getToken(MariaDBParser.ENCRYPTION_KEY_ADMIN, 0); }
		public TerminalNode END() { return getToken(MariaDBParser.END, 0); }
		public TerminalNode ENDS() { return getToken(MariaDBParser.ENDS, 0); }
		public TerminalNode ENGINE() { return getToken(MariaDBParser.ENGINE, 0); }
		public TerminalNode ENGINE_ATTRIBUTE() { return getToken(MariaDBParser.ENGINE_ATTRIBUTE, 0); }
		public TerminalNode ENGINES() { return getToken(MariaDBParser.ENGINES, 0); }
		public TerminalNode ERROR() { return getToken(MariaDBParser.ERROR, 0); }
		public TerminalNode ERRORS() { return getToken(MariaDBParser.ERRORS, 0); }
		public TerminalNode ESCAPE() { return getToken(MariaDBParser.ESCAPE, 0); }
		public TerminalNode EUR() { return getToken(MariaDBParser.EUR, 0); }
		public TerminalNode EVEN() { return getToken(MariaDBParser.EVEN, 0); }
		public TerminalNode EVENT() { return getToken(MariaDBParser.EVENT, 0); }
		public TerminalNode EVENTS() { return getToken(MariaDBParser.EVENTS, 0); }
		public TerminalNode EVERY() { return getToken(MariaDBParser.EVERY, 0); }
		public TerminalNode EXCEPT() { return getToken(MariaDBParser.EXCEPT, 0); }
		public TerminalNode EXCHANGE() { return getToken(MariaDBParser.EXCHANGE, 0); }
		public TerminalNode EXCLUSIVE() { return getToken(MariaDBParser.EXCLUSIVE, 0); }
		public TerminalNode EXPIRE() { return getToken(MariaDBParser.EXPIRE, 0); }
		public TerminalNode EXPORT() { return getToken(MariaDBParser.EXPORT, 0); }
		public TerminalNode EXTENDED() { return getToken(MariaDBParser.EXTENDED, 0); }
		public TerminalNode EXTENT_SIZE() { return getToken(MariaDBParser.EXTENT_SIZE, 0); }
		public TerminalNode FAILED_LOGIN_ATTEMPTS() { return getToken(MariaDBParser.FAILED_LOGIN_ATTEMPTS, 0); }
		public TerminalNode FAST() { return getToken(MariaDBParser.FAST, 0); }
		public TerminalNode FAULTS() { return getToken(MariaDBParser.FAULTS, 0); }
		public TerminalNode FIELDS() { return getToken(MariaDBParser.FIELDS, 0); }
		public TerminalNode FILE_BLOCK_SIZE() { return getToken(MariaDBParser.FILE_BLOCK_SIZE, 0); }
		public TerminalNode FILTER() { return getToken(MariaDBParser.FILTER, 0); }
		public TerminalNode FIREWALL_ADMIN() { return getToken(MariaDBParser.FIREWALL_ADMIN, 0); }
		public TerminalNode FIREWALL_USER() { return getToken(MariaDBParser.FIREWALL_USER, 0); }
		public TerminalNode FIRST() { return getToken(MariaDBParser.FIRST, 0); }
		public TerminalNode FIXED() { return getToken(MariaDBParser.FIXED, 0); }
		public TerminalNode FLUSH() { return getToken(MariaDBParser.FLUSH, 0); }
		public TerminalNode FOLLOWS() { return getToken(MariaDBParser.FOLLOWS, 0); }
		public TerminalNode FOUND() { return getToken(MariaDBParser.FOUND, 0); }
		public TerminalNode FULL() { return getToken(MariaDBParser.FULL, 0); }
		public TerminalNode FUNCTION() { return getToken(MariaDBParser.FUNCTION, 0); }
		public TerminalNode GENERAL() { return getToken(MariaDBParser.GENERAL, 0); }
		public TerminalNode GLOBAL() { return getToken(MariaDBParser.GLOBAL, 0); }
		public TerminalNode GRANTS() { return getToken(MariaDBParser.GRANTS, 0); }
		public TerminalNode GROUP() { return getToken(MariaDBParser.GROUP, 0); }
		public TerminalNode GROUP_CONCAT() { return getToken(MariaDBParser.GROUP_CONCAT, 0); }
		public TerminalNode GROUP_REPLICATION() { return getToken(MariaDBParser.GROUP_REPLICATION, 0); }
		public TerminalNode GROUP_REPLICATION_ADMIN() { return getToken(MariaDBParser.GROUP_REPLICATION_ADMIN, 0); }
		public TerminalNode HANDLER() { return getToken(MariaDBParser.HANDLER, 0); }
		public TerminalNode HASH() { return getToken(MariaDBParser.HASH, 0); }
		public TerminalNode HELP() { return getToken(MariaDBParser.HELP, 0); }
		public TerminalNode HISTORY() { return getToken(MariaDBParser.HISTORY, 0); }
		public TerminalNode HOST() { return getToken(MariaDBParser.HOST, 0); }
		public TerminalNode HOSTS() { return getToken(MariaDBParser.HOSTS, 0); }
		public TerminalNode IDENTIFIED() { return getToken(MariaDBParser.IDENTIFIED, 0); }
		public TerminalNode IGNORED() { return getToken(MariaDBParser.IGNORED, 0); }
		public TerminalNode IGNORE_SERVER_IDS() { return getToken(MariaDBParser.IGNORE_SERVER_IDS, 0); }
		public TerminalNode IMPORT() { return getToken(MariaDBParser.IMPORT, 0); }
		public TerminalNode INDEXES() { return getToken(MariaDBParser.INDEXES, 0); }
		public TerminalNode INITIAL_SIZE() { return getToken(MariaDBParser.INITIAL_SIZE, 0); }
		public TerminalNode INNODB_REDO_LOG_ARCHIVE() { return getToken(MariaDBParser.INNODB_REDO_LOG_ARCHIVE, 0); }
		public TerminalNode INPLACE() { return getToken(MariaDBParser.INPLACE, 0); }
		public TerminalNode INSERT_METHOD() { return getToken(MariaDBParser.INSERT_METHOD, 0); }
		public TerminalNode INSTALL() { return getToken(MariaDBParser.INSTALL, 0); }
		public TerminalNode INSTANCE() { return getToken(MariaDBParser.INSTANCE, 0); }
		public TerminalNode INSTANT() { return getToken(MariaDBParser.INSTANT, 0); }
		public TerminalNode INTERNAL() { return getToken(MariaDBParser.INTERNAL, 0); }
		public TerminalNode INVOKE() { return getToken(MariaDBParser.INVOKE, 0); }
		public TerminalNode INVOKER() { return getToken(MariaDBParser.INVOKER, 0); }
		public TerminalNode IO() { return getToken(MariaDBParser.IO, 0); }
		public TerminalNode IO_THREAD() { return getToken(MariaDBParser.IO_THREAD, 0); }
		public TerminalNode IPC() { return getToken(MariaDBParser.IPC, 0); }
		public TerminalNode ISO() { return getToken(MariaDBParser.ISO, 0); }
		public TerminalNode ISOLATION() { return getToken(MariaDBParser.ISOLATION, 0); }
		public TerminalNode ISSUER() { return getToken(MariaDBParser.ISSUER, 0); }
		public TerminalNode JIS() { return getToken(MariaDBParser.JIS, 0); }
		public TerminalNode JSON() { return getToken(MariaDBParser.JSON, 0); }
		public TerminalNode KEY_BLOCK_SIZE() { return getToken(MariaDBParser.KEY_BLOCK_SIZE, 0); }
		public TerminalNode LAMBDA() { return getToken(MariaDBParser.LAMBDA, 0); }
		public TerminalNode LANGUAGE() { return getToken(MariaDBParser.LANGUAGE, 0); }
		public TerminalNode LAST() { return getToken(MariaDBParser.LAST, 0); }
		public TerminalNode LATERAL() { return getToken(MariaDBParser.LATERAL, 0); }
		public TerminalNode LEAVES() { return getToken(MariaDBParser.LEAVES, 0); }
		public TerminalNode LESS() { return getToken(MariaDBParser.LESS, 0); }
		public TerminalNode LEVEL() { return getToken(MariaDBParser.LEVEL, 0); }
		public TerminalNode LIST() { return getToken(MariaDBParser.LIST, 0); }
		public TerminalNode LOCAL() { return getToken(MariaDBParser.LOCAL, 0); }
		public TerminalNode LOCALES() { return getToken(MariaDBParser.LOCALES, 0); }
		public TerminalNode LOGFILE() { return getToken(MariaDBParser.LOGFILE, 0); }
		public TerminalNode LOGS() { return getToken(MariaDBParser.LOGS, 0); }
		public TerminalNode MASTER() { return getToken(MariaDBParser.MASTER, 0); }
		public TerminalNode MASTER_AUTO_POSITION() { return getToken(MariaDBParser.MASTER_AUTO_POSITION, 0); }
		public TerminalNode MASTER_CONNECT_RETRY() { return getToken(MariaDBParser.MASTER_CONNECT_RETRY, 0); }
		public TerminalNode MASTER_DELAY() { return getToken(MariaDBParser.MASTER_DELAY, 0); }
		public TerminalNode MASTER_HEARTBEAT_PERIOD() { return getToken(MariaDBParser.MASTER_HEARTBEAT_PERIOD, 0); }
		public TerminalNode MASTER_HOST() { return getToken(MariaDBParser.MASTER_HOST, 0); }
		public TerminalNode MASTER_LOG_FILE() { return getToken(MariaDBParser.MASTER_LOG_FILE, 0); }
		public TerminalNode MASTER_LOG_POS() { return getToken(MariaDBParser.MASTER_LOG_POS, 0); }
		public TerminalNode MASTER_PASSWORD() { return getToken(MariaDBParser.MASTER_PASSWORD, 0); }
		public TerminalNode MASTER_PORT() { return getToken(MariaDBParser.MASTER_PORT, 0); }
		public TerminalNode MASTER_RETRY_COUNT() { return getToken(MariaDBParser.MASTER_RETRY_COUNT, 0); }
		public TerminalNode MASTER_SSL() { return getToken(MariaDBParser.MASTER_SSL, 0); }
		public TerminalNode MASTER_SSL_CA() { return getToken(MariaDBParser.MASTER_SSL_CA, 0); }
		public TerminalNode MASTER_SSL_CAPATH() { return getToken(MariaDBParser.MASTER_SSL_CAPATH, 0); }
		public TerminalNode MASTER_SSL_CERT() { return getToken(MariaDBParser.MASTER_SSL_CERT, 0); }
		public TerminalNode MASTER_SSL_CIPHER() { return getToken(MariaDBParser.MASTER_SSL_CIPHER, 0); }
		public TerminalNode MASTER_SSL_CRL() { return getToken(MariaDBParser.MASTER_SSL_CRL, 0); }
		public TerminalNode MASTER_SSL_CRLPATH() { return getToken(MariaDBParser.MASTER_SSL_CRLPATH, 0); }
		public TerminalNode MASTER_SSL_KEY() { return getToken(MariaDBParser.MASTER_SSL_KEY, 0); }
		public TerminalNode MASTER_TLS_VERSION() { return getToken(MariaDBParser.MASTER_TLS_VERSION, 0); }
		public TerminalNode MASTER_USER() { return getToken(MariaDBParser.MASTER_USER, 0); }
		public TerminalNode MAX_CONNECTIONS_PER_HOUR() { return getToken(MariaDBParser.MAX_CONNECTIONS_PER_HOUR, 0); }
		public TerminalNode MAX_QUERIES_PER_HOUR() { return getToken(MariaDBParser.MAX_QUERIES_PER_HOUR, 0); }
		public TerminalNode MAX() { return getToken(MariaDBParser.MAX, 0); }
		public TerminalNode MAX_ROWS() { return getToken(MariaDBParser.MAX_ROWS, 0); }
		public TerminalNode MAX_SIZE() { return getToken(MariaDBParser.MAX_SIZE, 0); }
		public TerminalNode MAX_UPDATES_PER_HOUR() { return getToken(MariaDBParser.MAX_UPDATES_PER_HOUR, 0); }
		public TerminalNode MAX_USER_CONNECTIONS() { return getToken(MariaDBParser.MAX_USER_CONNECTIONS, 0); }
		public TerminalNode MEDIUM() { return getToken(MariaDBParser.MEDIUM, 0); }
		public TerminalNode MEMBER() { return getToken(MariaDBParser.MEMBER, 0); }
		public TerminalNode MEMORY() { return getToken(MariaDBParser.MEMORY, 0); }
		public TerminalNode MERGE() { return getToken(MariaDBParser.MERGE, 0); }
		public TerminalNode MESSAGE_TEXT() { return getToken(MariaDBParser.MESSAGE_TEXT, 0); }
		public TerminalNode MID() { return getToken(MariaDBParser.MID, 0); }
		public TerminalNode MIGRATE() { return getToken(MariaDBParser.MIGRATE, 0); }
		public TerminalNode MIN() { return getToken(MariaDBParser.MIN, 0); }
		public TerminalNode MIN_ROWS() { return getToken(MariaDBParser.MIN_ROWS, 0); }
		public TerminalNode MODE() { return getToken(MariaDBParser.MODE, 0); }
		public TerminalNode MODIFY() { return getToken(MariaDBParser.MODIFY, 0); }
		public TerminalNode MUTEX() { return getToken(MariaDBParser.MUTEX, 0); }
		public TerminalNode MYSQL() { return getToken(MariaDBParser.MYSQL, 0); }
		public TerminalNode MYSQL_ERRNO() { return getToken(MariaDBParser.MYSQL_ERRNO, 0); }
		public TerminalNode NAME() { return getToken(MariaDBParser.NAME, 0); }
		public TerminalNode NAMES() { return getToken(MariaDBParser.NAMES, 0); }
		public TerminalNode NCHAR() { return getToken(MariaDBParser.NCHAR, 0); }
		public TerminalNode NDB_STORED_USER() { return getToken(MariaDBParser.NDB_STORED_USER, 0); }
		public TerminalNode NESTED() { return getToken(MariaDBParser.NESTED, 0); }
		public TerminalNode NEVER() { return getToken(MariaDBParser.NEVER, 0); }
		public TerminalNode NEXT() { return getToken(MariaDBParser.NEXT, 0); }
		public TerminalNode NO() { return getToken(MariaDBParser.NO, 0); }
		public TerminalNode NOCOPY() { return getToken(MariaDBParser.NOCOPY, 0); }
		public TerminalNode NODEGROUP() { return getToken(MariaDBParser.NODEGROUP, 0); }
		public TerminalNode NONE() { return getToken(MariaDBParser.NONE, 0); }
		public TerminalNode NOWAIT() { return getToken(MariaDBParser.NOWAIT, 0); }
		public TerminalNode NUMBER() { return getToken(MariaDBParser.NUMBER, 0); }
		public TerminalNode ODBC() { return getToken(MariaDBParser.ODBC, 0); }
		public TerminalNode OFFLINE() { return getToken(MariaDBParser.OFFLINE, 0); }
		public TerminalNode OFFSET() { return getToken(MariaDBParser.OFFSET, 0); }
		public TerminalNode OF() { return getToken(MariaDBParser.OF, 0); }
		public TerminalNode OJ() { return getToken(MariaDBParser.OJ, 0); }
		public TerminalNode OLD_PASSWORD() { return getToken(MariaDBParser.OLD_PASSWORD, 0); }
		public TerminalNode ONE() { return getToken(MariaDBParser.ONE, 0); }
		public TerminalNode ONLINE() { return getToken(MariaDBParser.ONLINE, 0); }
		public TerminalNode ONLY() { return getToken(MariaDBParser.ONLY, 0); }
		public TerminalNode OPEN() { return getToken(MariaDBParser.OPEN, 0); }
		public TerminalNode OPTIMIZER_COSTS() { return getToken(MariaDBParser.OPTIMIZER_COSTS, 0); }
		public TerminalNode OPTIONAL() { return getToken(MariaDBParser.OPTIONAL, 0); }
		public TerminalNode OPTIONS() { return getToken(MariaDBParser.OPTIONS, 0); }
		public TerminalNode ORDER() { return getToken(MariaDBParser.ORDER, 0); }
		public TerminalNode ORDINALITY() { return getToken(MariaDBParser.ORDINALITY, 0); }
		public TerminalNode OWNER() { return getToken(MariaDBParser.OWNER, 0); }
		public TerminalNode PACKAGE() { return getToken(MariaDBParser.PACKAGE, 0); }
		public TerminalNode PACK_KEYS() { return getToken(MariaDBParser.PACK_KEYS, 0); }
		public TerminalNode PAGE() { return getToken(MariaDBParser.PAGE, 0); }
		public TerminalNode PARSER() { return getToken(MariaDBParser.PARSER, 0); }
		public TerminalNode PARTIAL() { return getToken(MariaDBParser.PARTIAL, 0); }
		public TerminalNode PARTITIONING() { return getToken(MariaDBParser.PARTITIONING, 0); }
		public TerminalNode PARTITIONS() { return getToken(MariaDBParser.PARTITIONS, 0); }
		public TerminalNode PASSWORD() { return getToken(MariaDBParser.PASSWORD, 0); }
		public TerminalNode PASSWORDLESS_USER_ADMIN() { return getToken(MariaDBParser.PASSWORDLESS_USER_ADMIN, 0); }
		public TerminalNode PASSWORD_LOCK_TIME() { return getToken(MariaDBParser.PASSWORD_LOCK_TIME, 0); }
		public TerminalNode PATH() { return getToken(MariaDBParser.PATH, 0); }
		public TerminalNode PERSIST_RO_VARIABLES_ADMIN() { return getToken(MariaDBParser.PERSIST_RO_VARIABLES_ADMIN, 0); }
		public TerminalNode PHASE() { return getToken(MariaDBParser.PHASE, 0); }
		public TerminalNode PLUGINS() { return getToken(MariaDBParser.PLUGINS, 0); }
		public TerminalNode PLUGIN_DIR() { return getToken(MariaDBParser.PLUGIN_DIR, 0); }
		public TerminalNode PLUGIN() { return getToken(MariaDBParser.PLUGIN, 0); }
		public TerminalNode PORT() { return getToken(MariaDBParser.PORT, 0); }
		public TerminalNode PRECEDES() { return getToken(MariaDBParser.PRECEDES, 0); }
		public TerminalNode PREPARE() { return getToken(MariaDBParser.PREPARE, 0); }
		public TerminalNode PRESERVE() { return getToken(MariaDBParser.PRESERVE, 0); }
		public TerminalNode PREV() { return getToken(MariaDBParser.PREV, 0); }
		public TerminalNode PRIMARY() { return getToken(MariaDBParser.PRIMARY, 0); }
		public TerminalNode PROCESSLIST() { return getToken(MariaDBParser.PROCESSLIST, 0); }
		public TerminalNode PROFILE() { return getToken(MariaDBParser.PROFILE, 0); }
		public TerminalNode PROFILES() { return getToken(MariaDBParser.PROFILES, 0); }
		public TerminalNode PROXY() { return getToken(MariaDBParser.PROXY, 0); }
		public TerminalNode QUERY() { return getToken(MariaDBParser.QUERY, 0); }
		public TerminalNode QUERY_RESPONSE_TIME() { return getToken(MariaDBParser.QUERY_RESPONSE_TIME, 0); }
		public TerminalNode QUICK() { return getToken(MariaDBParser.QUICK, 0); }
		public TerminalNode REBUILD() { return getToken(MariaDBParser.REBUILD, 0); }
		public TerminalNode RECOVER() { return getToken(MariaDBParser.RECOVER, 0); }
		public TerminalNode RECURSIVE() { return getToken(MariaDBParser.RECURSIVE, 0); }
		public TerminalNode REDO_BUFFER_SIZE() { return getToken(MariaDBParser.REDO_BUFFER_SIZE, 0); }
		public TerminalNode REDUNDANT() { return getToken(MariaDBParser.REDUNDANT, 0); }
		public TerminalNode RELAY() { return getToken(MariaDBParser.RELAY, 0); }
		public TerminalNode RELAYLOG() { return getToken(MariaDBParser.RELAYLOG, 0); }
		public TerminalNode RELAY_LOG_FILE() { return getToken(MariaDBParser.RELAY_LOG_FILE, 0); }
		public TerminalNode RELAY_LOG_POS() { return getToken(MariaDBParser.RELAY_LOG_POS, 0); }
		public TerminalNode REMOVE() { return getToken(MariaDBParser.REMOVE, 0); }
		public TerminalNode REORGANIZE() { return getToken(MariaDBParser.REORGANIZE, 0); }
		public TerminalNode REPAIR() { return getToken(MariaDBParser.REPAIR, 0); }
		public TerminalNode REPLICAS() { return getToken(MariaDBParser.REPLICAS, 0); }
		public TerminalNode REPLICATE_DO_DB() { return getToken(MariaDBParser.REPLICATE_DO_DB, 0); }
		public TerminalNode REPLICATE_DO_TABLE() { return getToken(MariaDBParser.REPLICATE_DO_TABLE, 0); }
		public TerminalNode REPLICATE_IGNORE_DB() { return getToken(MariaDBParser.REPLICATE_IGNORE_DB, 0); }
		public TerminalNode REPLICATE_IGNORE_TABLE() { return getToken(MariaDBParser.REPLICATE_IGNORE_TABLE, 0); }
		public TerminalNode REPLICATE_REWRITE_DB() { return getToken(MariaDBParser.REPLICATE_REWRITE_DB, 0); }
		public TerminalNode REPLICATE_WILD_DO_TABLE() { return getToken(MariaDBParser.REPLICATE_WILD_DO_TABLE, 0); }
		public TerminalNode REPLICATE_WILD_IGNORE_TABLE() { return getToken(MariaDBParser.REPLICATE_WILD_IGNORE_TABLE, 0); }
		public TerminalNode REPLICATION() { return getToken(MariaDBParser.REPLICATION, 0); }
		public TerminalNode REPLICATION_APPLIER() { return getToken(MariaDBParser.REPLICATION_APPLIER, 0); }
		public TerminalNode REPLICATION_SLAVE_ADMIN() { return getToken(MariaDBParser.REPLICATION_SLAVE_ADMIN, 0); }
		public TerminalNode RESET() { return getToken(MariaDBParser.RESET, 0); }
		public TerminalNode RESOURCE_GROUP_ADMIN() { return getToken(MariaDBParser.RESOURCE_GROUP_ADMIN, 0); }
		public TerminalNode RESOURCE_GROUP_USER() { return getToken(MariaDBParser.RESOURCE_GROUP_USER, 0); }
		public TerminalNode RESUME() { return getToken(MariaDBParser.RESUME, 0); }
		public TerminalNode RETURNED_SQLSTATE() { return getToken(MariaDBParser.RETURNED_SQLSTATE, 0); }
		public TerminalNode RETURNS() { return getToken(MariaDBParser.RETURNS, 0); }
		public TerminalNode REUSE() { return getToken(MariaDBParser.REUSE, 0); }
		public TerminalNode ROLE() { return getToken(MariaDBParser.ROLE, 0); }
		public TerminalNode ROLE_ADMIN() { return getToken(MariaDBParser.ROLE_ADMIN, 0); }
		public TerminalNode ROLLBACK() { return getToken(MariaDBParser.ROLLBACK, 0); }
		public TerminalNode ROLLUP() { return getToken(MariaDBParser.ROLLUP, 0); }
		public TerminalNode ROTATE() { return getToken(MariaDBParser.ROTATE, 0); }
		public TerminalNode ROW() { return getToken(MariaDBParser.ROW, 0); }
		public TerminalNode ROWS() { return getToken(MariaDBParser.ROWS, 0); }
		public TerminalNode ROW_FORMAT() { return getToken(MariaDBParser.ROW_FORMAT, 0); }
		public TerminalNode RTREE() { return getToken(MariaDBParser.RTREE, 0); }
		public TerminalNode S3() { return getToken(MariaDBParser.S3, 0); }
		public TerminalNode SAVEPOINT() { return getToken(MariaDBParser.SAVEPOINT, 0); }
		public TerminalNode SCHEDULE() { return getToken(MariaDBParser.SCHEDULE, 0); }
		public TerminalNode SCHEMA_NAME() { return getToken(MariaDBParser.SCHEMA_NAME, 0); }
		public TerminalNode SECURITY() { return getToken(MariaDBParser.SECURITY, 0); }
		public TerminalNode SECONDARY_ENGINE_ATTRIBUTE() { return getToken(MariaDBParser.SECONDARY_ENGINE_ATTRIBUTE, 0); }
		public TerminalNode SERIAL() { return getToken(MariaDBParser.SERIAL, 0); }
		public TerminalNode SERVER() { return getToken(MariaDBParser.SERVER, 0); }
		public TerminalNode SESSION() { return getToken(MariaDBParser.SESSION, 0); }
		public TerminalNode SESSION_VARIABLES_ADMIN() { return getToken(MariaDBParser.SESSION_VARIABLES_ADMIN, 0); }
		public TerminalNode SET_USER_ID() { return getToken(MariaDBParser.SET_USER_ID, 0); }
		public TerminalNode SHARE() { return getToken(MariaDBParser.SHARE, 0); }
		public TerminalNode SHARED() { return getToken(MariaDBParser.SHARED, 0); }
		public TerminalNode SHOW_ROUTINE() { return getToken(MariaDBParser.SHOW_ROUTINE, 0); }
		public TerminalNode SIGNED() { return getToken(MariaDBParser.SIGNED, 0); }
		public TerminalNode SIMPLE() { return getToken(MariaDBParser.SIMPLE, 0); }
		public TerminalNode SLAVE() { return getToken(MariaDBParser.SLAVE, 0); }
		public TerminalNode SLAVES() { return getToken(MariaDBParser.SLAVES, 0); }
		public TerminalNode SLOW() { return getToken(MariaDBParser.SLOW, 0); }
		public TerminalNode SNAPSHOT() { return getToken(MariaDBParser.SNAPSHOT, 0); }
		public TerminalNode SOCKET() { return getToken(MariaDBParser.SOCKET, 0); }
		public TerminalNode SOME() { return getToken(MariaDBParser.SOME, 0); }
		public TerminalNode SONAME() { return getToken(MariaDBParser.SONAME, 0); }
		public TerminalNode SOUNDS() { return getToken(MariaDBParser.SOUNDS, 0); }
		public TerminalNode SOURCE() { return getToken(MariaDBParser.SOURCE, 0); }
		public TerminalNode SQL_AFTER_GTIDS() { return getToken(MariaDBParser.SQL_AFTER_GTIDS, 0); }
		public TerminalNode SQL_AFTER_MTS_GAPS() { return getToken(MariaDBParser.SQL_AFTER_MTS_GAPS, 0); }
		public TerminalNode SQL_BEFORE_GTIDS() { return getToken(MariaDBParser.SQL_BEFORE_GTIDS, 0); }
		public TerminalNode SQL_BUFFER_RESULT() { return getToken(MariaDBParser.SQL_BUFFER_RESULT, 0); }
		public TerminalNode SQL_CACHE() { return getToken(MariaDBParser.SQL_CACHE, 0); }
		public TerminalNode SQL_NO_CACHE() { return getToken(MariaDBParser.SQL_NO_CACHE, 0); }
		public TerminalNode SQL_THREAD() { return getToken(MariaDBParser.SQL_THREAD, 0); }
		public TerminalNode STACKED() { return getToken(MariaDBParser.STACKED, 0); }
		public TerminalNode START() { return getToken(MariaDBParser.START, 0); }
		public TerminalNode STARTS() { return getToken(MariaDBParser.STARTS, 0); }
		public TerminalNode STATS_AUTO_RECALC() { return getToken(MariaDBParser.STATS_AUTO_RECALC, 0); }
		public TerminalNode STATS_PERSISTENT() { return getToken(MariaDBParser.STATS_PERSISTENT, 0); }
		public TerminalNode STATS_SAMPLE_PAGES() { return getToken(MariaDBParser.STATS_SAMPLE_PAGES, 0); }
		public TerminalNode STATUS() { return getToken(MariaDBParser.STATUS, 0); }
		public TerminalNode STD() { return getToken(MariaDBParser.STD, 0); }
		public TerminalNode STDDEV() { return getToken(MariaDBParser.STDDEV, 0); }
		public TerminalNode STDDEV_POP() { return getToken(MariaDBParser.STDDEV_POP, 0); }
		public TerminalNode STDDEV_SAMP() { return getToken(MariaDBParser.STDDEV_SAMP, 0); }
		public TerminalNode STOP() { return getToken(MariaDBParser.STOP, 0); }
		public TerminalNode STORAGE() { return getToken(MariaDBParser.STORAGE, 0); }
		public TerminalNode STRING() { return getToken(MariaDBParser.STRING, 0); }
		public TerminalNode SUBCLASS_ORIGIN() { return getToken(MariaDBParser.SUBCLASS_ORIGIN, 0); }
		public TerminalNode SUBJECT() { return getToken(MariaDBParser.SUBJECT, 0); }
		public TerminalNode SUBPARTITION() { return getToken(MariaDBParser.SUBPARTITION, 0); }
		public TerminalNode SUBPARTITIONS() { return getToken(MariaDBParser.SUBPARTITIONS, 0); }
		public TerminalNode SUM() { return getToken(MariaDBParser.SUM, 0); }
		public TerminalNode SUSPEND() { return getToken(MariaDBParser.SUSPEND, 0); }
		public TerminalNode SWAPS() { return getToken(MariaDBParser.SWAPS, 0); }
		public TerminalNode SWITCHES() { return getToken(MariaDBParser.SWITCHES, 0); }
		public TerminalNode SYSTEM_VARIABLES_ADMIN() { return getToken(MariaDBParser.SYSTEM_VARIABLES_ADMIN, 0); }
		public TerminalNode TABLE_NAME() { return getToken(MariaDBParser.TABLE_NAME, 0); }
		public TerminalNode TABLESPACE() { return getToken(MariaDBParser.TABLESPACE, 0); }
		public TerminalNode TABLE_ENCRYPTION_ADMIN() { return getToken(MariaDBParser.TABLE_ENCRYPTION_ADMIN, 0); }
		public TerminalNode TABLE_TYPE() { return getToken(MariaDBParser.TABLE_TYPE, 0); }
		public TerminalNode TEMPORARY() { return getToken(MariaDBParser.TEMPORARY, 0); }
		public TerminalNode TEMPTABLE() { return getToken(MariaDBParser.TEMPTABLE, 0); }
		public TerminalNode THAN() { return getToken(MariaDBParser.THAN, 0); }
		public TerminalNode TRADITIONAL() { return getToken(MariaDBParser.TRADITIONAL, 0); }
		public TerminalNode TRANSACTION() { return getToken(MariaDBParser.TRANSACTION, 0); }
		public TerminalNode TRANSACTIONAL() { return getToken(MariaDBParser.TRANSACTIONAL, 0); }
		public TerminalNode TRIGGERS() { return getToken(MariaDBParser.TRIGGERS, 0); }
		public TerminalNode TRUNCATE() { return getToken(MariaDBParser.TRUNCATE, 0); }
		public TerminalNode TYPES() { return getToken(MariaDBParser.TYPES, 0); }
		public TerminalNode UNBOUNDED() { return getToken(MariaDBParser.UNBOUNDED, 0); }
		public TerminalNode UNDEFINED() { return getToken(MariaDBParser.UNDEFINED, 0); }
		public TerminalNode UNDOFILE() { return getToken(MariaDBParser.UNDOFILE, 0); }
		public TerminalNode UNDO_BUFFER_SIZE() { return getToken(MariaDBParser.UNDO_BUFFER_SIZE, 0); }
		public TerminalNode UNINSTALL() { return getToken(MariaDBParser.UNINSTALL, 0); }
		public TerminalNode UNKNOWN() { return getToken(MariaDBParser.UNKNOWN, 0); }
		public TerminalNode UNTIL() { return getToken(MariaDBParser.UNTIL, 0); }
		public TerminalNode UPGRADE() { return getToken(MariaDBParser.UPGRADE, 0); }
		public TerminalNode USA() { return getToken(MariaDBParser.USA, 0); }
		public TerminalNode USER() { return getToken(MariaDBParser.USER, 0); }
		public TerminalNode USE_FRM() { return getToken(MariaDBParser.USE_FRM, 0); }
		public TerminalNode USER_RESOURCES() { return getToken(MariaDBParser.USER_RESOURCES, 0); }
		public TerminalNode VALIDATION() { return getToken(MariaDBParser.VALIDATION, 0); }
		public TerminalNode VALUE() { return getToken(MariaDBParser.VALUE, 0); }
		public TerminalNode VAR_POP() { return getToken(MariaDBParser.VAR_POP, 0); }
		public TerminalNode VAR_SAMP() { return getToken(MariaDBParser.VAR_SAMP, 0); }
		public TerminalNode VARIABLES() { return getToken(MariaDBParser.VARIABLES, 0); }
		public TerminalNode VARIANCE() { return getToken(MariaDBParser.VARIANCE, 0); }
		public TerminalNode VERSION_TOKEN_ADMIN() { return getToken(MariaDBParser.VERSION_TOKEN_ADMIN, 0); }
		public TerminalNode VIEW() { return getToken(MariaDBParser.VIEW, 0); }
		public TerminalNode VIRTUAL() { return getToken(MariaDBParser.VIRTUAL, 0); }
		public TerminalNode WAIT() { return getToken(MariaDBParser.WAIT, 0); }
		public TerminalNode WARNINGS() { return getToken(MariaDBParser.WARNINGS, 0); }
		public TerminalNode WITHOUT() { return getToken(MariaDBParser.WITHOUT, 0); }
		public TerminalNode WORK() { return getToken(MariaDBParser.WORK, 0); }
		public TerminalNode WRAPPER() { return getToken(MariaDBParser.WRAPPER, 0); }
		public TerminalNode WSREP_MEMBERSHIP() { return getToken(MariaDBParser.WSREP_MEMBERSHIP, 0); }
		public TerminalNode WSREP_STATUS() { return getToken(MariaDBParser.WSREP_STATUS, 0); }
		public TerminalNode X509() { return getToken(MariaDBParser.X509, 0); }
		public TerminalNode XA() { return getToken(MariaDBParser.XA, 0); }
		public TerminalNode XA_RECOVER_ADMIN() { return getToken(MariaDBParser.XA_RECOVER_ADMIN, 0); }
		public TerminalNode XML() { return getToken(MariaDBParser.XML, 0); }
		public TerminalNode YES() { return getToken(MariaDBParser.YES, 0); }
		public TerminalNode BINLOG_MONITOR() { return getToken(MariaDBParser.BINLOG_MONITOR, 0); }
		public TerminalNode BINLOG_REPLAY() { return getToken(MariaDBParser.BINLOG_REPLAY, 0); }
		public TerminalNode CURRENT_ROLE() { return getToken(MariaDBParser.CURRENT_ROLE, 0); }
		public TerminalNode CYCLE() { return getToken(MariaDBParser.CYCLE, 0); }
		public TerminalNode ENCRYPTED() { return getToken(MariaDBParser.ENCRYPTED, 0); }
		public TerminalNode ENCRYPTION_KEY_ID() { return getToken(MariaDBParser.ENCRYPTION_KEY_ID, 0); }
		public TerminalNode FEDERATED_ADMIN() { return getToken(MariaDBParser.FEDERATED_ADMIN, 0); }
		public TerminalNode INCREMENT() { return getToken(MariaDBParser.INCREMENT, 0); }
		public TerminalNode LASTVAL() { return getToken(MariaDBParser.LASTVAL, 0); }
		public TerminalNode LOCKED() { return getToken(MariaDBParser.LOCKED, 0); }
		public TerminalNode MAXVALUE() { return getToken(MariaDBParser.MAXVALUE, 0); }
		public TerminalNode MINVALUE() { return getToken(MariaDBParser.MINVALUE, 0); }
		public TerminalNode NEXTVAL() { return getToken(MariaDBParser.NEXTVAL, 0); }
		public TerminalNode NOCACHE() { return getToken(MariaDBParser.NOCACHE, 0); }
		public TerminalNode NOCYCLE() { return getToken(MariaDBParser.NOCYCLE, 0); }
		public TerminalNode NOMAXVALUE() { return getToken(MariaDBParser.NOMAXVALUE, 0); }
		public TerminalNode NOMINVALUE() { return getToken(MariaDBParser.NOMINVALUE, 0); }
		public TerminalNode PERSISTENT() { return getToken(MariaDBParser.PERSISTENT, 0); }
		public TerminalNode PREVIOUS() { return getToken(MariaDBParser.PREVIOUS, 0); }
		public TerminalNode READ_ONLY_ADMIN() { return getToken(MariaDBParser.READ_ONLY_ADMIN, 0); }
		public TerminalNode REPLICA() { return getToken(MariaDBParser.REPLICA, 0); }
		public TerminalNode REPLICATION_MASTER_ADMIN() { return getToken(MariaDBParser.REPLICATION_MASTER_ADMIN, 0); }
		public TerminalNode RESTART() { return getToken(MariaDBParser.RESTART, 0); }
		public TerminalNode SEQUENCE() { return getToken(MariaDBParser.SEQUENCE, 0); }
		public TerminalNode SETVAL() { return getToken(MariaDBParser.SETVAL, 0); }
		public TerminalNode SKIP_() { return getToken(MariaDBParser.SKIP_, 0); }
		public TerminalNode STATEMENT() { return getToken(MariaDBParser.STATEMENT, 0); }
		public TerminalNode VIA() { return getToken(MariaDBParser.VIA, 0); }
		public TerminalNode MONITOR() { return getToken(MariaDBParser.MONITOR, 0); }
		public TerminalNode READ_ONLY() { return getToken(MariaDBParser.READ_ONLY, 0); }
		public TerminalNode REPLAY() { return getToken(MariaDBParser.REPLAY, 0); }
		public TerminalNode USER_STATISTICS() { return getToken(MariaDBParser.USER_STATISTICS, 0); }
		public TerminalNode CLIENT_STATISTICS() { return getToken(MariaDBParser.CLIENT_STATISTICS, 0); }
		public TerminalNode INDEX_STATISTICS() { return getToken(MariaDBParser.INDEX_STATISTICS, 0); }
		public TerminalNode TABLE_STATISTICS() { return getToken(MariaDBParser.TABLE_STATISTICS, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterKeywordsCanBeId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitKeywordsCanBeId(this);
		}
	}

	public final KeywordsCanBeIdContext keywordsCanBeId() throws RecognitionException {
		KeywordsCanBeIdContext _localctx = new KeywordsCanBeIdContext(_ctx, getState());
		enterRule(_localctx, 726, RULE_keywordsCanBeId);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7615);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << ATTRIBUTE) | (1L << BODY) | (1L << BUCKETS) | (1L << CONDITION) | (1L << CURRENT) | (1L << CURRENT_ROLE) | (1L << CURRENT_USER) | (1L << DEFAULT) | (1L << DIAGNOSTICS) | (1L << EMPTY) | (1L << EXCEPT))) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & ((1L << (GROUP - 73)) | (1L << (IGNORED - 73)) | (1L << (LATERAL - 73)) | (1L << (LOCKED - 73)) | (1L << (MAXVALUE - 73)) | (1L << (MINVALUE - 73)) | (1L << (NUMBER - 73)) | (1L << (OPTIONAL - 73)) | (1L << (ORDER - 73)) | (1L << (PRIMARY - 73)) | (1L << (PACKAGE - 73)))) != 0) || ((((_la - 158)) & ~0x3f) == 0 && ((1L << (_la - 158)) & ((1L << (SKIP_ - 158)) | (1L << (STACKED - 158)) | (1L << (STATEMENT - 158)))) != 0) || ((((_la - 239)) & ~0x3f) == 0 && ((1L << (_la - 239)) & ((1L << (SERIAL - 239)) | (1L << (NESTED - 239)) | (1L << (ORDINALITY - 239)) | (1L << (PATH - 239)) | (1L << (AVG - 239)) | (1L << (BIT_AND - 239)) | (1L << (BIT_OR - 239)) | (1L << (BIT_XOR - 239)) | (1L << (COUNT - 239)) | (1L << (GROUP_CONCAT - 239)) | (1L << (MAX - 239)) | (1L << (MIN - 239)))) != 0) || ((((_la - 305)) & ~0x3f) == 0 && ((1L << (_la - 305)) & ((1L << (STD - 305)) | (1L << (STDDEV - 305)) | (1L << (STDDEV_POP - 305)) | (1L << (STDDEV_SAMP - 305)) | (1L << (SUM - 305)) | (1L << (VAR_POP - 305)) | (1L << (VAR_SAMP - 305)) | (1L << (VARIANCE - 305)) | (1L << (ACCOUNT - 305)) | (1L << (ACTION - 305)) | (1L << (AFTER - 305)) | (1L << (AGGREGATE - 305)) | (1L << (ALGORITHM - 305)) | (1L << (ANY - 305)) | (1L << (AT - 305)) | (1L << (AUTHORS - 305)) | (1L << (AUTOCOMMIT - 305)) | (1L << (AUTOEXTEND_SIZE - 305)) | (1L << (AUTO_INCREMENT - 305)) | (1L << (AVG_ROW_LENGTH - 305)) | (1L << (BEGIN - 305)) | (1L << (BINLOG - 305)) | (1L << (BIT - 305)) | (1L << (BLOCK - 305)) | (1L << (BOOL - 305)) | (1L << (BOOLEAN - 305)) | (1L << (BTREE - 305)) | (1L << (CACHE - 305)) | (1L << (CASCADED - 305)) | (1L << (CHAIN - 305)) | (1L << (CHANGED - 305)) | (1L << (CHANNEL - 305)) | (1L << (CHECKSUM - 305)) | (1L << (PAGE_CHECKSUM - 305)) | (1L << (CIPHER - 305)) | (1L << (CLASS_ORIGIN - 305)) | (1L << (CLIENT - 305)) | (1L << (CLOSE - 305)) | (1L << (CLUSTERING - 305)) | (1L << (COALESCE - 305)) | (1L << (CODE - 305)) | (1L << (COLUMNS - 305)) | (1L << (COLUMN_FORMAT - 305)) | (1L << (COLUMN_NAME - 305)) | (1L << (COMMENT - 305)))) != 0) || ((((_la - 369)) & ~0x3f) == 0 && ((1L << (_la - 369)) & ((1L << (COMMIT - 369)) | (1L << (COMPACT - 369)) | (1L << (COMPLETION - 369)) | (1L << (COMPRESSED - 369)) | (1L << (COMPRESSION - 369)) | (1L << (CONCURRENT - 369)) | (1L << (CONNECT - 369)) | (1L << (CONNECTION - 369)) | (1L << (CONSISTENT - 369)) | (1L << (CONSTRAINT_CATALOG - 369)) | (1L << (CONSTRAINT_SCHEMA - 369)) | (1L << (CONSTRAINT_NAME - 369)) | (1L << (CONTAINS - 369)) | (1L << (CONTEXT - 369)) | (1L << (CONTRIBUTORS - 369)) | (1L << (COPY - 369)) | (1L << (CPU - 369)) | (1L << (CYCLE - 369)) | (1L << (CURSOR_NAME - 369)) | (1L << (DATA - 369)) | (1L << (DATAFILE - 369)) | (1L << (DEALLOCATE - 369)) | (1L << (DEFAULT_AUTH - 369)) | (1L << (DEFINER - 369)) | (1L << (DELAY_KEY_WRITE - 369)) | (1L << (DES_KEY_FILE - 369)) | (1L << (DIRECTORY - 369)) | (1L << (DISABLE - 369)) | (1L << (DISCARD - 369)) | (1L << (DISK - 369)) | (1L << (DO - 369)) | (1L << (DUMPFILE - 369)) | (1L << (DUPLICATE - 369)) | (1L << (DYNAMIC - 369)) | (1L << (ENABLE - 369)) | (1L << (ENCRYPTED - 369)) | (1L << (ENCRYPTION - 369)) | (1L << (ENCRYPTION_KEY_ID - 369)) | (1L << (END - 369)) | (1L << (ENDS - 369)) | (1L << (ENGINE - 369)) | (1L << (ENGINES - 369)) | (1L << (ERROR - 369)) | (1L << (ERRORS - 369)) | (1L << (ESCAPE - 369)) | (1L << (EVEN - 369)) | (1L << (EVENT - 369)) | (1L << (EVENTS - 369)) | (1L << (EVERY - 369)) | (1L << (EXCHANGE - 369)) | (1L << (EXCLUSIVE - 369)) | (1L << (EXPIRE - 369)) | (1L << (EXPORT - 369)) | (1L << (EXTENDED - 369)) | (1L << (EXTENT_SIZE - 369)) | (1L << (FAILED_LOGIN_ATTEMPTS - 369)) | (1L << (FAST - 369)) | (1L << (FAULTS - 369)) | (1L << (FIELDS - 369)) | (1L << (FILE_BLOCK_SIZE - 369)) | (1L << (FILTER - 369)) | (1L << (FIRST - 369)) | (1L << (FIXED - 369)) | (1L << (FLUSH - 369)))) != 0) || ((((_la - 434)) & ~0x3f) == 0 && ((1L << (_la - 434)) & ((1L << (FOLLOWS - 434)) | (1L << (FOUND - 434)) | (1L << (FULL - 434)) | (1L << (FUNCTION - 434)) | (1L << (GENERAL - 434)) | (1L << (GLOBAL - 434)) | (1L << (GRANTS - 434)) | (1L << (GROUP_REPLICATION - 434)) | (1L << (HANDLER - 434)) | (1L << (HASH - 434)) | (1L << (HELP - 434)) | (1L << (HISTORY - 434)) | (1L << (HOST - 434)) | (1L << (HOSTS - 434)) | (1L << (IDENTIFIED - 434)) | (1L << (IGNORE_SERVER_IDS - 434)) | (1L << (IMPORT - 434)) | (1L << (INCREMENT - 434)) | (1L << (INDEXES - 434)) | (1L << (INITIAL_SIZE - 434)) | (1L << (INPLACE - 434)) | (1L << (INSERT_METHOD - 434)) | (1L << (INSTALL - 434)) | (1L << (INSTANCE - 434)) | (1L << (INSTANT - 434)) | (1L << (INVOKER - 434)) | (1L << (IO - 434)) | (1L << (IO_THREAD - 434)) | (1L << (IPC - 434)) | (1L << (ISOLATION - 434)) | (1L << (ISSUER - 434)) | (1L << (JSON - 434)) | (1L << (KEY_BLOCK_SIZE - 434)) | (1L << (LANGUAGE - 434)) | (1L << (LAST - 434)) | (1L << (LEAVES - 434)) | (1L << (LESS - 434)) | (1L << (LEVEL - 434)) | (1L << (LIST - 434)) | (1L << (LOCAL - 434)) | (1L << (LOCALES - 434)) | (1L << (LOGFILE - 434)) | (1L << (LOGS - 434)) | (1L << (MASTER - 434)) | (1L << (MASTER_AUTO_POSITION - 434)) | (1L << (MASTER_CONNECT_RETRY - 434)) | (1L << (MASTER_DELAY - 434)) | (1L << (MASTER_HEARTBEAT_PERIOD - 434)) | (1L << (MASTER_HOST - 434)) | (1L << (MASTER_LOG_FILE - 434)) | (1L << (MASTER_LOG_POS - 434)) | (1L << (MASTER_PASSWORD - 434)) | (1L << (MASTER_PORT - 434)) | (1L << (MASTER_RETRY_COUNT - 434)) | (1L << (MASTER_SSL - 434)) | (1L << (MASTER_SSL_CA - 434)) | (1L << (MASTER_SSL_CAPATH - 434)) | (1L << (MASTER_SSL_CERT - 434)) | (1L << (MASTER_SSL_CIPHER - 434)) | (1L << (MASTER_SSL_CRL - 434)) | (1L << (MASTER_SSL_CRLPATH - 434)) | (1L << (MASTER_SSL_KEY - 434)) | (1L << (MASTER_TLS_VERSION - 434)))) != 0) || ((((_la - 498)) & ~0x3f) == 0 && ((1L << (_la - 498)) & ((1L << (MASTER_USER - 498)) | (1L << (MAX_CONNECTIONS_PER_HOUR - 498)) | (1L << (MAX_QUERIES_PER_HOUR - 498)) | (1L << (MAX_ROWS - 498)) | (1L << (MAX_SIZE - 498)) | (1L << (MAX_UPDATES_PER_HOUR - 498)) | (1L << (MAX_USER_CONNECTIONS - 498)) | (1L << (MEDIUM - 498)) | (1L << (MEMBER - 498)) | (1L << (MERGE - 498)) | (1L << (MESSAGE_TEXT - 498)) | (1L << (MID - 498)) | (1L << (MIGRATE - 498)) | (1L << (MIN_ROWS - 498)) | (1L << (MODE - 498)) | (1L << (MODIFY - 498)) | (1L << (MUTEX - 498)) | (1L << (MYSQL - 498)) | (1L << (MYSQL_ERRNO - 498)) | (1L << (NAME - 498)) | (1L << (NAMES - 498)) | (1L << (NCHAR - 498)) | (1L << (NEVER - 498)) | (1L << (NEXT - 498)) | (1L << (NO - 498)) | (1L << (NOCACHE - 498)) | (1L << (NOCOPY - 498)) | (1L << (NOCYCLE - 498)) | (1L << (NOMAXVALUE - 498)) | (1L << (NOMINVALUE - 498)) | (1L << (NOWAIT - 498)) | (1L << (NODEGROUP - 498)) | (1L << (NONE - 498)) | (1L << (ODBC - 498)) | (1L << (OFFLINE - 498)) | (1L << (OFFSET - 498)) | (1L << (OF - 498)) | (1L << (OJ - 498)) | (1L << (OLD_PASSWORD - 498)) | (1L << (ONE - 498)) | (1L << (ONLINE - 498)) | (1L << (ONLY - 498)) | (1L << (OPEN - 498)) | (1L << (OPTIMIZER_COSTS - 498)) | (1L << (OPTIONS - 498)) | (1L << (OWNER - 498)) | (1L << (PACK_KEYS - 498)) | (1L << (PAGE - 498)) | (1L << (PARSER - 498)) | (1L << (PARTIAL - 498)) | (1L << (PARTITIONING - 498)) | (1L << (PARTITIONS - 498)) | (1L << (PASSWORD - 498)) | (1L << (PASSWORD_LOCK_TIME - 498)) | (1L << (PHASE - 498)) | (1L << (PLUGIN - 498)) | (1L << (PLUGIN_DIR - 498)) | (1L << (PLUGINS - 498)) | (1L << (PORT - 498)) | (1L << (PRECEDES - 498)) | (1L << (PREPARE - 498)))) != 0) || ((((_la - 562)) & ~0x3f) == 0 && ((1L << (_la - 562)) & ((1L << (PRESERVE - 562)) | (1L << (PREV - 562)) | (1L << (PROCESSLIST - 562)) | (1L << (PROFILE - 562)) | (1L << (PROFILES - 562)) | (1L << (PROXY - 562)) | (1L << (QUERY - 562)) | (1L << (QUERY_RESPONSE_TIME - 562)) | (1L << (QUICK - 562)) | (1L << (REBUILD - 562)) | (1L << (RECOVER - 562)) | (1L << (RECURSIVE - 562)) | (1L << (REDO_BUFFER_SIZE - 562)) | (1L << (REDUNDANT - 562)) | (1L << (RELAY - 562)) | (1L << (RELAY_LOG_FILE - 562)) | (1L << (RELAY_LOG_POS - 562)) | (1L << (RELAYLOG - 562)) | (1L << (REMOVE - 562)) | (1L << (REORGANIZE - 562)) | (1L << (REPAIR - 562)) | (1L << (REPLICATE_DO_DB - 562)) | (1L << (REPLICATE_DO_TABLE - 562)) | (1L << (REPLICATE_IGNORE_DB - 562)) | (1L << (REPLICATE_IGNORE_TABLE - 562)) | (1L << (REPLICATE_REWRITE_DB - 562)) | (1L << (REPLICATE_WILD_DO_TABLE - 562)) | (1L << (REPLICATE_WILD_IGNORE_TABLE - 562)) | (1L << (REPLICATION - 562)) | (1L << (RESET - 562)) | (1L << (RESTART - 562)) | (1L << (RESUME - 562)) | (1L << (RETURNED_SQLSTATE - 562)) | (1L << (RETURNS - 562)) | (1L << (REUSE - 562)) | (1L << (ROLE - 562)) | (1L << (ROLLBACK - 562)) | (1L << (ROLLUP - 562)) | (1L << (ROTATE - 562)) | (1L << (ROW - 562)) | (1L << (ROWS - 562)) | (1L << (ROW_FORMAT - 562)) | (1L << (RTREE - 562)) | (1L << (SAVEPOINT - 562)) | (1L << (SCHEDULE - 562)) | (1L << (SECURITY - 562)) | (1L << (SEQUENCE - 562)) | (1L << (SERVER - 562)) | (1L << (SESSION - 562)) | (1L << (SHARE - 562)) | (1L << (SHARED - 562)) | (1L << (SIGNED - 562)) | (1L << (SIMPLE - 562)) | (1L << (SLAVE - 562)) | (1L << (SLAVES - 562)) | (1L << (SLOW - 562)) | (1L << (SNAPSHOT - 562)) | (1L << (SOCKET - 562)) | (1L << (SOME - 562)) | (1L << (SONAME - 562)) | (1L << (SOUNDS - 562)) | (1L << (SOURCE - 562)) | (1L << (SQL_AFTER_GTIDS - 562)))) != 0) || ((((_la - 626)) & ~0x3f) == 0 && ((1L << (_la - 626)) & ((1L << (SQL_AFTER_MTS_GAPS - 626)) | (1L << (SQL_BEFORE_GTIDS - 626)) | (1L << (SQL_BUFFER_RESULT - 626)) | (1L << (SQL_CACHE - 626)) | (1L << (SQL_NO_CACHE - 626)) | (1L << (SQL_THREAD - 626)) | (1L << (START - 626)) | (1L << (STARTS - 626)) | (1L << (STATS_AUTO_RECALC - 626)) | (1L << (STATS_PERSISTENT - 626)) | (1L << (STATS_SAMPLE_PAGES - 626)) | (1L << (STATUS - 626)) | (1L << (STOP - 626)) | (1L << (STORAGE - 626)) | (1L << (STRING - 626)) | (1L << (SUBCLASS_ORIGIN - 626)) | (1L << (SUBJECT - 626)) | (1L << (SUBPARTITION - 626)) | (1L << (SUBPARTITIONS - 626)) | (1L << (SUSPEND - 626)) | (1L << (SWAPS - 626)) | (1L << (SWITCHES - 626)) | (1L << (TABLE_NAME - 626)) | (1L << (TABLESPACE - 626)) | (1L << (TABLE_TYPE - 626)) | (1L << (TEMPORARY - 626)) | (1L << (TEMPTABLE - 626)) | (1L << (THAN - 626)) | (1L << (TRADITIONAL - 626)) | (1L << (TRANSACTION - 626)) | (1L << (TRANSACTIONAL - 626)) | (1L << (TRIGGERS - 626)) | (1L << (TRUNCATE - 626)) | (1L << (TYPES - 626)) | (1L << (UNBOUNDED - 626)) | (1L << (UNDEFINED - 626)) | (1L << (UNDOFILE - 626)) | (1L << (UNDO_BUFFER_SIZE - 626)) | (1L << (UNINSTALL - 626)) | (1L << (UNKNOWN - 626)) | (1L << (UNTIL - 626)) | (1L << (UPGRADE - 626)) | (1L << (USER - 626)) | (1L << (USE_FRM - 626)) | (1L << (USER_RESOURCES - 626)) | (1L << (VALIDATION - 626)) | (1L << (VALUE - 626)) | (1L << (VARIABLES - 626)) | (1L << (VIEW - 626)) | (1L << (VIRTUAL - 626)) | (1L << (WAIT - 626)) | (1L << (WARNINGS - 626)) | (1L << (WITHOUT - 626)) | (1L << (WORK - 626)) | (1L << (WRAPPER - 626)) | (1L << (WSREP_MEMBERSHIP - 626)) | (1L << (WSREP_STATUS - 626)) | (1L << (X509 - 626)) | (1L << (XA - 626)) | (1L << (XML - 626)) | (1L << (YES - 626)))) != 0) || ((((_la - 690)) & ~0x3f) == 0 && ((1L << (_la - 690)) & ((1L << (EUR - 690)) | (1L << (USA - 690)) | (1L << (JIS - 690)) | (1L << (ISO - 690)) | (1L << (INTERNAL - 690)) | (1L << (USER_STATISTICS - 690)) | (1L << (CLIENT_STATISTICS - 690)) | (1L << (INDEX_STATISTICS - 690)) | (1L << (TABLE_STATISTICS - 690)) | (1L << (ADMIN - 690)) | (1L << (AUDIT_ADMIN - 690)) | (1L << (BACKUP_ADMIN - 690)) | (1L << (BINLOG_ADMIN - 690)) | (1L << (BINLOG_ENCRYPTION_ADMIN - 690)) | (1L << (CLONE_ADMIN - 690)) | (1L << (CONNECTION_ADMIN - 690)) | (1L << (ENCRYPTION_KEY_ADMIN - 690)) | (1L << (FIREWALL_ADMIN - 690)) | (1L << (FIREWALL_USER - 690)) | (1L << (GROUP_REPLICATION_ADMIN - 690)) | (1L << (INNODB_REDO_LOG_ARCHIVE - 690)) | (1L << (INVOKE - 690)) | (1L << (LAMBDA - 690)) | (1L << (NDB_STORED_USER - 690)) | (1L << (PASSWORDLESS_USER_ADMIN - 690)) | (1L << (PERSIST_RO_VARIABLES_ADMIN - 690)) | (1L << (REPLICATION_APPLIER - 690)) | (1L << (REPLICATION_SLAVE_ADMIN - 690)) | (1L << (RESOURCE_GROUP_ADMIN - 690)) | (1L << (RESOURCE_GROUP_USER - 690)) | (1L << (ROLE_ADMIN - 690)) | (1L << (S3 - 690)) | (1L << (SESSION_VARIABLES_ADMIN - 690)) | (1L << (SET_USER_ID - 690)) | (1L << (SHOW_ROUTINE - 690)) | (1L << (SYSTEM_VARIABLES_ADMIN - 690)) | (1L << (TABLE_ENCRYPTION_ADMIN - 690)) | (1L << (VERSION_TOKEN_ADMIN - 690)) | (1L << (XA_RECOVER_ADMIN - 690)))) != 0) || _la==MEMORY || _la==CATALOG_NAME || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE || _la==SCHEMA_NAME || ((((_la - 1113)) & ~0x3f) == 0 && ((1L << (_la - 1113)) & ((1L << (VIA - 1113)) | (1L << (LASTVAL - 1113)) | (1L << (NEXTVAL - 1113)) | (1L << (SETVAL - 1113)) | (1L << (PREVIOUS - 1113)) | (1L << (PERSISTENT - 1113)) | (1L << (BINLOG_MONITOR - 1113)) | (1L << (BINLOG_REPLAY - 1113)) | (1L << (FEDERATED_ADMIN - 1113)) | (1L << (READ_ONLY_ADMIN - 1113)) | (1L << (REPLICA - 1113)) | (1L << (REPLICAS - 1113)) | (1L << (REPLICATION_MASTER_ADMIN - 1113)) | (1L << (MONITOR - 1113)) | (1L << (READ_ONLY - 1113)) | (1L << (REPLAY - 1113)))) != 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;
	}

	public static class FunctionNameBaseContext extends ParserRuleContext {
		public TerminalNode ABS() { return getToken(MariaDBParser.ABS, 0); }
		public TerminalNode ACOS() { return getToken(MariaDBParser.ACOS, 0); }
		public TerminalNode ADDDATE() { return getToken(MariaDBParser.ADDDATE, 0); }
		public TerminalNode ADDTIME() { return getToken(MariaDBParser.ADDTIME, 0); }
		public TerminalNode AES_DECRYPT() { return getToken(MariaDBParser.AES_DECRYPT, 0); }
		public TerminalNode AES_ENCRYPT() { return getToken(MariaDBParser.AES_ENCRYPT, 0); }
		public TerminalNode AREA() { return getToken(MariaDBParser.AREA, 0); }
		public TerminalNode ASBINARY() { return getToken(MariaDBParser.ASBINARY, 0); }
		public TerminalNode ASIN() { return getToken(MariaDBParser.ASIN, 0); }
		public TerminalNode ASTEXT() { return getToken(MariaDBParser.ASTEXT, 0); }
		public TerminalNode ASWKB() { return getToken(MariaDBParser.ASWKB, 0); }
		public TerminalNode ASWKT() { return getToken(MariaDBParser.ASWKT, 0); }
		public TerminalNode ASYMMETRIC_DECRYPT() { return getToken(MariaDBParser.ASYMMETRIC_DECRYPT, 0); }
		public TerminalNode ASYMMETRIC_DERIVE() { return getToken(MariaDBParser.ASYMMETRIC_DERIVE, 0); }
		public TerminalNode ASYMMETRIC_ENCRYPT() { return getToken(MariaDBParser.ASYMMETRIC_ENCRYPT, 0); }
		public TerminalNode ASYMMETRIC_SIGN() { return getToken(MariaDBParser.ASYMMETRIC_SIGN, 0); }
		public TerminalNode ASYMMETRIC_VERIFY() { return getToken(MariaDBParser.ASYMMETRIC_VERIFY, 0); }
		public TerminalNode ATAN() { return getToken(MariaDBParser.ATAN, 0); }
		public TerminalNode ATAN2() { return getToken(MariaDBParser.ATAN2, 0); }
		public TerminalNode BENCHMARK() { return getToken(MariaDBParser.BENCHMARK, 0); }
		public TerminalNode BIN() { return getToken(MariaDBParser.BIN, 0); }
		public TerminalNode BIT_COUNT() { return getToken(MariaDBParser.BIT_COUNT, 0); }
		public TerminalNode BIT_LENGTH() { return getToken(MariaDBParser.BIT_LENGTH, 0); }
		public TerminalNode BUFFER() { return getToken(MariaDBParser.BUFFER, 0); }
		public TerminalNode CEIL() { return getToken(MariaDBParser.CEIL, 0); }
		public TerminalNode CEILING() { return getToken(MariaDBParser.CEILING, 0); }
		public TerminalNode CENTROID() { return getToken(MariaDBParser.CENTROID, 0); }
		public TerminalNode CHARACTER_LENGTH() { return getToken(MariaDBParser.CHARACTER_LENGTH, 0); }
		public TerminalNode CHARSET() { return getToken(MariaDBParser.CHARSET, 0); }
		public TerminalNode CHAR_LENGTH() { return getToken(MariaDBParser.CHAR_LENGTH, 0); }
		public TerminalNode COERCIBILITY() { return getToken(MariaDBParser.COERCIBILITY, 0); }
		public TerminalNode COLLATION() { return getToken(MariaDBParser.COLLATION, 0); }
		public TerminalNode COMPRESS() { return getToken(MariaDBParser.COMPRESS, 0); }
		public TerminalNode CONCAT() { return getToken(MariaDBParser.CONCAT, 0); }
		public TerminalNode CONCAT_WS() { return getToken(MariaDBParser.CONCAT_WS, 0); }
		public TerminalNode CONNECTION_ID() { return getToken(MariaDBParser.CONNECTION_ID, 0); }
		public TerminalNode CONV() { return getToken(MariaDBParser.CONV, 0); }
		public TerminalNode CONVERT_TZ() { return getToken(MariaDBParser.CONVERT_TZ, 0); }
		public TerminalNode COS() { return getToken(MariaDBParser.COS, 0); }
		public TerminalNode COT() { return getToken(MariaDBParser.COT, 0); }
		public TerminalNode COUNT() { return getToken(MariaDBParser.COUNT, 0); }
		public TerminalNode CRC32() { return getToken(MariaDBParser.CRC32, 0); }
		public TerminalNode CREATE_ASYMMETRIC_PRIV_KEY() { return getToken(MariaDBParser.CREATE_ASYMMETRIC_PRIV_KEY, 0); }
		public TerminalNode CREATE_ASYMMETRIC_PUB_KEY() { return getToken(MariaDBParser.CREATE_ASYMMETRIC_PUB_KEY, 0); }
		public TerminalNode CREATE_DH_PARAMETERS() { return getToken(MariaDBParser.CREATE_DH_PARAMETERS, 0); }
		public TerminalNode CREATE_DIGEST() { return getToken(MariaDBParser.CREATE_DIGEST, 0); }
		public TerminalNode CROSSES() { return getToken(MariaDBParser.CROSSES, 0); }
		public TerminalNode CUME_DIST() { return getToken(MariaDBParser.CUME_DIST, 0); }
		public TerminalNode DATABASE() { return getToken(MariaDBParser.DATABASE, 0); }
		public TerminalNode DATE() { return getToken(MariaDBParser.DATE, 0); }
		public TerminalNode DATEDIFF() { return getToken(MariaDBParser.DATEDIFF, 0); }
		public TerminalNode DATE_FORMAT() { return getToken(MariaDBParser.DATE_FORMAT, 0); }
		public TerminalNode DAY() { return getToken(MariaDBParser.DAY, 0); }
		public TerminalNode DAYNAME() { return getToken(MariaDBParser.DAYNAME, 0); }
		public TerminalNode DAYOFMONTH() { return getToken(MariaDBParser.DAYOFMONTH, 0); }
		public TerminalNode DAYOFWEEK() { return getToken(MariaDBParser.DAYOFWEEK, 0); }
		public TerminalNode DAYOFYEAR() { return getToken(MariaDBParser.DAYOFYEAR, 0); }
		public TerminalNode DECODE() { return getToken(MariaDBParser.DECODE, 0); }
		public TerminalNode DEGREES() { return getToken(MariaDBParser.DEGREES, 0); }
		public TerminalNode DENSE_RANK() { return getToken(MariaDBParser.DENSE_RANK, 0); }
		public TerminalNode DES_DECRYPT() { return getToken(MariaDBParser.DES_DECRYPT, 0); }
		public TerminalNode DES_ENCRYPT() { return getToken(MariaDBParser.DES_ENCRYPT, 0); }
		public TerminalNode DIMENSION() { return getToken(MariaDBParser.DIMENSION, 0); }
		public TerminalNode DISJOINT() { return getToken(MariaDBParser.DISJOINT, 0); }
		public TerminalNode ELT() { return getToken(MariaDBParser.ELT, 0); }
		public TerminalNode ENCODE() { return getToken(MariaDBParser.ENCODE, 0); }
		public TerminalNode ENCRYPT() { return getToken(MariaDBParser.ENCRYPT, 0); }
		public TerminalNode ENDPOINT() { return getToken(MariaDBParser.ENDPOINT, 0); }
		public TerminalNode ENVELOPE() { return getToken(MariaDBParser.ENVELOPE, 0); }
		public TerminalNode EQUALS() { return getToken(MariaDBParser.EQUALS, 0); }
		public TerminalNode EXP() { return getToken(MariaDBParser.EXP, 0); }
		public TerminalNode EXPORT_SET() { return getToken(MariaDBParser.EXPORT_SET, 0); }
		public TerminalNode EXTERIORRING() { return getToken(MariaDBParser.EXTERIORRING, 0); }
		public TerminalNode EXTRACTVALUE() { return getToken(MariaDBParser.EXTRACTVALUE, 0); }
		public TerminalNode FIELD() { return getToken(MariaDBParser.FIELD, 0); }
		public TerminalNode FIND_IN_SET() { return getToken(MariaDBParser.FIND_IN_SET, 0); }
		public TerminalNode FIRST_VALUE() { return getToken(MariaDBParser.FIRST_VALUE, 0); }
		public TerminalNode FLOOR() { return getToken(MariaDBParser.FLOOR, 0); }
		public TerminalNode FORMAT() { return getToken(MariaDBParser.FORMAT, 0); }
		public TerminalNode FOUND_ROWS() { return getToken(MariaDBParser.FOUND_ROWS, 0); }
		public TerminalNode FROM_BASE64() { return getToken(MariaDBParser.FROM_BASE64, 0); }
		public TerminalNode FROM_DAYS() { return getToken(MariaDBParser.FROM_DAYS, 0); }
		public TerminalNode FROM_UNIXTIME() { return getToken(MariaDBParser.FROM_UNIXTIME, 0); }
		public TerminalNode GEOMCOLLFROMTEXT() { return getToken(MariaDBParser.GEOMCOLLFROMTEXT, 0); }
		public TerminalNode GEOMCOLLFROMWKB() { return getToken(MariaDBParser.GEOMCOLLFROMWKB, 0); }
		public TerminalNode GEOMETRYCOLLECTION() { return getToken(MariaDBParser.GEOMETRYCOLLECTION, 0); }
		public TerminalNode GEOMETRYCOLLECTIONFROMTEXT() { return getToken(MariaDBParser.GEOMETRYCOLLECTIONFROMTEXT, 0); }
		public TerminalNode GEOMETRYCOLLECTIONFROMWKB() { return getToken(MariaDBParser.GEOMETRYCOLLECTIONFROMWKB, 0); }
		public TerminalNode GEOMETRYFROMTEXT() { return getToken(MariaDBParser.GEOMETRYFROMTEXT, 0); }
		public TerminalNode GEOMETRYFROMWKB() { return getToken(MariaDBParser.GEOMETRYFROMWKB, 0); }
		public TerminalNode GEOMETRYN() { return getToken(MariaDBParser.GEOMETRYN, 0); }
		public TerminalNode GEOMETRYTYPE() { return getToken(MariaDBParser.GEOMETRYTYPE, 0); }
		public TerminalNode GEOMFROMTEXT() { return getToken(MariaDBParser.GEOMFROMTEXT, 0); }
		public TerminalNode GEOMFROMWKB() { return getToken(MariaDBParser.GEOMFROMWKB, 0); }
		public TerminalNode GET_FORMAT() { return getToken(MariaDBParser.GET_FORMAT, 0); }
		public TerminalNode GET_LOCK() { return getToken(MariaDBParser.GET_LOCK, 0); }
		public TerminalNode GLENGTH() { return getToken(MariaDBParser.GLENGTH, 0); }
		public TerminalNode GREATEST() { return getToken(MariaDBParser.GREATEST, 0); }
		public TerminalNode GTID_SUBSET() { return getToken(MariaDBParser.GTID_SUBSET, 0); }
		public TerminalNode GTID_SUBTRACT() { return getToken(MariaDBParser.GTID_SUBTRACT, 0); }
		public TerminalNode HEX() { return getToken(MariaDBParser.HEX, 0); }
		public TerminalNode HOUR() { return getToken(MariaDBParser.HOUR, 0); }
		public TerminalNode IFNULL() { return getToken(MariaDBParser.IFNULL, 0); }
		public TerminalNode INET6_ATON() { return getToken(MariaDBParser.INET6_ATON, 0); }
		public TerminalNode INET6_NTOA() { return getToken(MariaDBParser.INET6_NTOA, 0); }
		public TerminalNode INET_ATON() { return getToken(MariaDBParser.INET_ATON, 0); }
		public TerminalNode INET_NTOA() { return getToken(MariaDBParser.INET_NTOA, 0); }
		public TerminalNode INSTR() { return getToken(MariaDBParser.INSTR, 0); }
		public TerminalNode INTERIORRINGN() { return getToken(MariaDBParser.INTERIORRINGN, 0); }
		public TerminalNode INTERSECTS() { return getToken(MariaDBParser.INTERSECTS, 0); }
		public TerminalNode INVISIBLE() { return getToken(MariaDBParser.INVISIBLE, 0); }
		public TerminalNode ISCLOSED() { return getToken(MariaDBParser.ISCLOSED, 0); }
		public TerminalNode ISEMPTY() { return getToken(MariaDBParser.ISEMPTY, 0); }
		public TerminalNode ISNULL() { return getToken(MariaDBParser.ISNULL, 0); }
		public TerminalNode ISSIMPLE() { return getToken(MariaDBParser.ISSIMPLE, 0); }
		public TerminalNode IS_FREE_LOCK() { return getToken(MariaDBParser.IS_FREE_LOCK, 0); }
		public TerminalNode IS_IPV4() { return getToken(MariaDBParser.IS_IPV4, 0); }
		public TerminalNode IS_IPV4_COMPAT() { return getToken(MariaDBParser.IS_IPV4_COMPAT, 0); }
		public TerminalNode IS_IPV4_MAPPED() { return getToken(MariaDBParser.IS_IPV4_MAPPED, 0); }
		public TerminalNode IS_IPV6() { return getToken(MariaDBParser.IS_IPV6, 0); }
		public TerminalNode IS_USED_LOCK() { return getToken(MariaDBParser.IS_USED_LOCK, 0); }
		public TerminalNode LAG() { return getToken(MariaDBParser.LAG, 0); }
		public TerminalNode LAST_INSERT_ID() { return getToken(MariaDBParser.LAST_INSERT_ID, 0); }
		public TerminalNode LAST_VALUE() { return getToken(MariaDBParser.LAST_VALUE, 0); }
		public TerminalNode LCASE() { return getToken(MariaDBParser.LCASE, 0); }
		public TerminalNode LEAD() { return getToken(MariaDBParser.LEAD, 0); }
		public TerminalNode LEAST() { return getToken(MariaDBParser.LEAST, 0); }
		public TerminalNode LEFT() { return getToken(MariaDBParser.LEFT, 0); }
		public TerminalNode LENGTH() { return getToken(MariaDBParser.LENGTH, 0); }
		public TerminalNode LINEFROMTEXT() { return getToken(MariaDBParser.LINEFROMTEXT, 0); }
		public TerminalNode LINEFROMWKB() { return getToken(MariaDBParser.LINEFROMWKB, 0); }
		public TerminalNode LINESTRING() { return getToken(MariaDBParser.LINESTRING, 0); }
		public TerminalNode LINESTRINGFROMTEXT() { return getToken(MariaDBParser.LINESTRINGFROMTEXT, 0); }
		public TerminalNode LINESTRINGFROMWKB() { return getToken(MariaDBParser.LINESTRINGFROMWKB, 0); }
		public TerminalNode LN() { return getToken(MariaDBParser.LN, 0); }
		public TerminalNode LOAD_FILE() { return getToken(MariaDBParser.LOAD_FILE, 0); }
		public TerminalNode LOCATE() { return getToken(MariaDBParser.LOCATE, 0); }
		public TerminalNode LOG() { return getToken(MariaDBParser.LOG, 0); }
		public TerminalNode LOG10() { return getToken(MariaDBParser.LOG10, 0); }
		public TerminalNode LOG2() { return getToken(MariaDBParser.LOG2, 0); }
		public TerminalNode LOWER() { return getToken(MariaDBParser.LOWER, 0); }
		public TerminalNode LPAD() { return getToken(MariaDBParser.LPAD, 0); }
		public TerminalNode LTRIM() { return getToken(MariaDBParser.LTRIM, 0); }
		public TerminalNode MAKEDATE() { return getToken(MariaDBParser.MAKEDATE, 0); }
		public TerminalNode MAKETIME() { return getToken(MariaDBParser.MAKETIME, 0); }
		public TerminalNode MAKE_SET() { return getToken(MariaDBParser.MAKE_SET, 0); }
		public TerminalNode MASTER_POS_WAIT() { return getToken(MariaDBParser.MASTER_POS_WAIT, 0); }
		public TerminalNode MBRCONTAINS() { return getToken(MariaDBParser.MBRCONTAINS, 0); }
		public TerminalNode MBRDISJOINT() { return getToken(MariaDBParser.MBRDISJOINT, 0); }
		public TerminalNode MBREQUAL() { return getToken(MariaDBParser.MBREQUAL, 0); }
		public TerminalNode MBRINTERSECTS() { return getToken(MariaDBParser.MBRINTERSECTS, 0); }
		public TerminalNode MBROVERLAPS() { return getToken(MariaDBParser.MBROVERLAPS, 0); }
		public TerminalNode MBRTOUCHES() { return getToken(MariaDBParser.MBRTOUCHES, 0); }
		public TerminalNode MBRWITHIN() { return getToken(MariaDBParser.MBRWITHIN, 0); }
		public TerminalNode MD5() { return getToken(MariaDBParser.MD5, 0); }
		public TerminalNode MICROSECOND() { return getToken(MariaDBParser.MICROSECOND, 0); }
		public TerminalNode MINUTE() { return getToken(MariaDBParser.MINUTE, 0); }
		public TerminalNode MLINEFROMTEXT() { return getToken(MariaDBParser.MLINEFROMTEXT, 0); }
		public TerminalNode MLINEFROMWKB() { return getToken(MariaDBParser.MLINEFROMWKB, 0); }
		public TerminalNode MOD() { return getToken(MariaDBParser.MOD, 0); }
		public TerminalNode MONTH() { return getToken(MariaDBParser.MONTH, 0); }
		public TerminalNode MONTHNAME() { return getToken(MariaDBParser.MONTHNAME, 0); }
		public TerminalNode MPOINTFROMTEXT() { return getToken(MariaDBParser.MPOINTFROMTEXT, 0); }
		public TerminalNode MPOINTFROMWKB() { return getToken(MariaDBParser.MPOINTFROMWKB, 0); }
		public TerminalNode MPOLYFROMTEXT() { return getToken(MariaDBParser.MPOLYFROMTEXT, 0); }
		public TerminalNode MPOLYFROMWKB() { return getToken(MariaDBParser.MPOLYFROMWKB, 0); }
		public TerminalNode MULTILINESTRING() { return getToken(MariaDBParser.MULTILINESTRING, 0); }
		public TerminalNode MULTILINESTRINGFROMTEXT() { return getToken(MariaDBParser.MULTILINESTRINGFROMTEXT, 0); }
		public TerminalNode MULTILINESTRINGFROMWKB() { return getToken(MariaDBParser.MULTILINESTRINGFROMWKB, 0); }
		public TerminalNode MULTIPOINT() { return getToken(MariaDBParser.MULTIPOINT, 0); }
		public TerminalNode MULTIPOINTFROMTEXT() { return getToken(MariaDBParser.MULTIPOINTFROMTEXT, 0); }
		public TerminalNode MULTIPOINTFROMWKB() { return getToken(MariaDBParser.MULTIPOINTFROMWKB, 0); }
		public TerminalNode MULTIPOLYGON() { return getToken(MariaDBParser.MULTIPOLYGON, 0); }
		public TerminalNode MULTIPOLYGONFROMTEXT() { return getToken(MariaDBParser.MULTIPOLYGONFROMTEXT, 0); }
		public TerminalNode MULTIPOLYGONFROMWKB() { return getToken(MariaDBParser.MULTIPOLYGONFROMWKB, 0); }
		public TerminalNode NAME_CONST() { return getToken(MariaDBParser.NAME_CONST, 0); }
		public TerminalNode NTH_VALUE() { return getToken(MariaDBParser.NTH_VALUE, 0); }
		public TerminalNode NTILE() { return getToken(MariaDBParser.NTILE, 0); }
		public TerminalNode NULLIF() { return getToken(MariaDBParser.NULLIF, 0); }
		public TerminalNode NUMGEOMETRIES() { return getToken(MariaDBParser.NUMGEOMETRIES, 0); }
		public TerminalNode NUMINTERIORRINGS() { return getToken(MariaDBParser.NUMINTERIORRINGS, 0); }
		public TerminalNode NUMPOINTS() { return getToken(MariaDBParser.NUMPOINTS, 0); }
		public TerminalNode OCT() { return getToken(MariaDBParser.OCT, 0); }
		public TerminalNode OCTET_LENGTH() { return getToken(MariaDBParser.OCTET_LENGTH, 0); }
		public TerminalNode ORD() { return getToken(MariaDBParser.ORD, 0); }
		public TerminalNode OVERLAPS() { return getToken(MariaDBParser.OVERLAPS, 0); }
		public TerminalNode PERCENT_RANK() { return getToken(MariaDBParser.PERCENT_RANK, 0); }
		public TerminalNode PERIOD_ADD() { return getToken(MariaDBParser.PERIOD_ADD, 0); }
		public TerminalNode PERIOD_DIFF() { return getToken(MariaDBParser.PERIOD_DIFF, 0); }
		public TerminalNode PI() { return getToken(MariaDBParser.PI, 0); }
		public TerminalNode POINT() { return getToken(MariaDBParser.POINT, 0); }
		public TerminalNode POINTFROMTEXT() { return getToken(MariaDBParser.POINTFROMTEXT, 0); }
		public TerminalNode POINTFROMWKB() { return getToken(MariaDBParser.POINTFROMWKB, 0); }
		public TerminalNode POINTN() { return getToken(MariaDBParser.POINTN, 0); }
		public TerminalNode POLYFROMTEXT() { return getToken(MariaDBParser.POLYFROMTEXT, 0); }
		public TerminalNode POLYFROMWKB() { return getToken(MariaDBParser.POLYFROMWKB, 0); }
		public TerminalNode POLYGON() { return getToken(MariaDBParser.POLYGON, 0); }
		public TerminalNode POLYGONFROMTEXT() { return getToken(MariaDBParser.POLYGONFROMTEXT, 0); }
		public TerminalNode POLYGONFROMWKB() { return getToken(MariaDBParser.POLYGONFROMWKB, 0); }
		public TerminalNode POSITION() { return getToken(MariaDBParser.POSITION, 0); }
		public TerminalNode POW() { return getToken(MariaDBParser.POW, 0); }
		public TerminalNode POWER() { return getToken(MariaDBParser.POWER, 0); }
		public TerminalNode QUARTER() { return getToken(MariaDBParser.QUARTER, 0); }
		public TerminalNode QUOTE() { return getToken(MariaDBParser.QUOTE, 0); }
		public TerminalNode RADIANS() { return getToken(MariaDBParser.RADIANS, 0); }
		public TerminalNode RAND() { return getToken(MariaDBParser.RAND, 0); }
		public TerminalNode RANK() { return getToken(MariaDBParser.RANK, 0); }
		public TerminalNode RANDOM_BYTES() { return getToken(MariaDBParser.RANDOM_BYTES, 0); }
		public TerminalNode RELEASE_LOCK() { return getToken(MariaDBParser.RELEASE_LOCK, 0); }
		public TerminalNode REVERSE() { return getToken(MariaDBParser.REVERSE, 0); }
		public TerminalNode RIGHT() { return getToken(MariaDBParser.RIGHT, 0); }
		public TerminalNode ROUND() { return getToken(MariaDBParser.ROUND, 0); }
		public TerminalNode ROW_COUNT() { return getToken(MariaDBParser.ROW_COUNT, 0); }
		public TerminalNode ROW_NUMBER() { return getToken(MariaDBParser.ROW_NUMBER, 0); }
		public TerminalNode RPAD() { return getToken(MariaDBParser.RPAD, 0); }
		public TerminalNode RTRIM() { return getToken(MariaDBParser.RTRIM, 0); }
		public TerminalNode SCHEMA() { return getToken(MariaDBParser.SCHEMA, 0); }
		public TerminalNode SECOND() { return getToken(MariaDBParser.SECOND, 0); }
		public TerminalNode SEC_TO_TIME() { return getToken(MariaDBParser.SEC_TO_TIME, 0); }
		public TerminalNode SESSION_USER() { return getToken(MariaDBParser.SESSION_USER, 0); }
		public TerminalNode SESSION_VARIABLES_ADMIN() { return getToken(MariaDBParser.SESSION_VARIABLES_ADMIN, 0); }
		public TerminalNode SHA() { return getToken(MariaDBParser.SHA, 0); }
		public TerminalNode SHA1() { return getToken(MariaDBParser.SHA1, 0); }
		public TerminalNode SHA2() { return getToken(MariaDBParser.SHA2, 0); }
		public TerminalNode SIGN() { return getToken(MariaDBParser.SIGN, 0); }
		public TerminalNode SIN() { return getToken(MariaDBParser.SIN, 0); }
		public TerminalNode SLEEP() { return getToken(MariaDBParser.SLEEP, 0); }
		public TerminalNode SOUNDEX() { return getToken(MariaDBParser.SOUNDEX, 0); }
		public TerminalNode SQL_THREAD_WAIT_AFTER_GTIDS() { return getToken(MariaDBParser.SQL_THREAD_WAIT_AFTER_GTIDS, 0); }
		public TerminalNode SQRT() { return getToken(MariaDBParser.SQRT, 0); }
		public TerminalNode SRID() { return getToken(MariaDBParser.SRID, 0); }
		public TerminalNode STARTPOINT() { return getToken(MariaDBParser.STARTPOINT, 0); }
		public TerminalNode STRCMP() { return getToken(MariaDBParser.STRCMP, 0); }
		public TerminalNode STR_TO_DATE() { return getToken(MariaDBParser.STR_TO_DATE, 0); }
		public TerminalNode ST_AREA() { return getToken(MariaDBParser.ST_AREA, 0); }
		public TerminalNode ST_ASBINARY() { return getToken(MariaDBParser.ST_ASBINARY, 0); }
		public TerminalNode ST_ASTEXT() { return getToken(MariaDBParser.ST_ASTEXT, 0); }
		public TerminalNode ST_ASWKB() { return getToken(MariaDBParser.ST_ASWKB, 0); }
		public TerminalNode ST_ASWKT() { return getToken(MariaDBParser.ST_ASWKT, 0); }
		public TerminalNode ST_BUFFER() { return getToken(MariaDBParser.ST_BUFFER, 0); }
		public TerminalNode ST_CENTROID() { return getToken(MariaDBParser.ST_CENTROID, 0); }
		public TerminalNode ST_CONTAINS() { return getToken(MariaDBParser.ST_CONTAINS, 0); }
		public TerminalNode ST_CROSSES() { return getToken(MariaDBParser.ST_CROSSES, 0); }
		public TerminalNode ST_DIFFERENCE() { return getToken(MariaDBParser.ST_DIFFERENCE, 0); }
		public TerminalNode ST_DIMENSION() { return getToken(MariaDBParser.ST_DIMENSION, 0); }
		public TerminalNode ST_DISJOINT() { return getToken(MariaDBParser.ST_DISJOINT, 0); }
		public TerminalNode ST_DISTANCE() { return getToken(MariaDBParser.ST_DISTANCE, 0); }
		public TerminalNode ST_ENDPOINT() { return getToken(MariaDBParser.ST_ENDPOINT, 0); }
		public TerminalNode ST_ENVELOPE() { return getToken(MariaDBParser.ST_ENVELOPE, 0); }
		public TerminalNode ST_EQUALS() { return getToken(MariaDBParser.ST_EQUALS, 0); }
		public TerminalNode ST_EXTERIORRING() { return getToken(MariaDBParser.ST_EXTERIORRING, 0); }
		public TerminalNode ST_GEOMCOLLFROMTEXT() { return getToken(MariaDBParser.ST_GEOMCOLLFROMTEXT, 0); }
		public TerminalNode ST_GEOMCOLLFROMTXT() { return getToken(MariaDBParser.ST_GEOMCOLLFROMTXT, 0); }
		public TerminalNode ST_GEOMCOLLFROMWKB() { return getToken(MariaDBParser.ST_GEOMCOLLFROMWKB, 0); }
		public TerminalNode ST_GEOMETRYCOLLECTIONFROMTEXT() { return getToken(MariaDBParser.ST_GEOMETRYCOLLECTIONFROMTEXT, 0); }
		public TerminalNode ST_GEOMETRYCOLLECTIONFROMWKB() { return getToken(MariaDBParser.ST_GEOMETRYCOLLECTIONFROMWKB, 0); }
		public TerminalNode ST_GEOMETRYFROMTEXT() { return getToken(MariaDBParser.ST_GEOMETRYFROMTEXT, 0); }
		public TerminalNode ST_GEOMETRYFROMWKB() { return getToken(MariaDBParser.ST_GEOMETRYFROMWKB, 0); }
		public TerminalNode ST_GEOMETRYN() { return getToken(MariaDBParser.ST_GEOMETRYN, 0); }
		public TerminalNode ST_GEOMETRYTYPE() { return getToken(MariaDBParser.ST_GEOMETRYTYPE, 0); }
		public TerminalNode ST_GEOMFROMTEXT() { return getToken(MariaDBParser.ST_GEOMFROMTEXT, 0); }
		public TerminalNode ST_GEOMFROMWKB() { return getToken(MariaDBParser.ST_GEOMFROMWKB, 0); }
		public TerminalNode ST_INTERIORRINGN() { return getToken(MariaDBParser.ST_INTERIORRINGN, 0); }
		public TerminalNode ST_INTERSECTION() { return getToken(MariaDBParser.ST_INTERSECTION, 0); }
		public TerminalNode ST_INTERSECTS() { return getToken(MariaDBParser.ST_INTERSECTS, 0); }
		public TerminalNode ST_ISCLOSED() { return getToken(MariaDBParser.ST_ISCLOSED, 0); }
		public TerminalNode ST_ISEMPTY() { return getToken(MariaDBParser.ST_ISEMPTY, 0); }
		public TerminalNode ST_ISSIMPLE() { return getToken(MariaDBParser.ST_ISSIMPLE, 0); }
		public TerminalNode ST_LINEFROMTEXT() { return getToken(MariaDBParser.ST_LINEFROMTEXT, 0); }
		public TerminalNode ST_LINEFROMWKB() { return getToken(MariaDBParser.ST_LINEFROMWKB, 0); }
		public TerminalNode ST_LINESTRINGFROMTEXT() { return getToken(MariaDBParser.ST_LINESTRINGFROMTEXT, 0); }
		public TerminalNode ST_LINESTRINGFROMWKB() { return getToken(MariaDBParser.ST_LINESTRINGFROMWKB, 0); }
		public TerminalNode ST_NUMGEOMETRIES() { return getToken(MariaDBParser.ST_NUMGEOMETRIES, 0); }
		public TerminalNode ST_NUMINTERIORRING() { return getToken(MariaDBParser.ST_NUMINTERIORRING, 0); }
		public TerminalNode ST_NUMINTERIORRINGS() { return getToken(MariaDBParser.ST_NUMINTERIORRINGS, 0); }
		public TerminalNode ST_NUMPOINTS() { return getToken(MariaDBParser.ST_NUMPOINTS, 0); }
		public TerminalNode ST_OVERLAPS() { return getToken(MariaDBParser.ST_OVERLAPS, 0); }
		public TerminalNode ST_POINTFROMTEXT() { return getToken(MariaDBParser.ST_POINTFROMTEXT, 0); }
		public TerminalNode ST_POINTFROMWKB() { return getToken(MariaDBParser.ST_POINTFROMWKB, 0); }
		public TerminalNode ST_POINTN() { return getToken(MariaDBParser.ST_POINTN, 0); }
		public TerminalNode ST_POLYFROMTEXT() { return getToken(MariaDBParser.ST_POLYFROMTEXT, 0); }
		public TerminalNode ST_POLYFROMWKB() { return getToken(MariaDBParser.ST_POLYFROMWKB, 0); }
		public TerminalNode ST_POLYGONFROMTEXT() { return getToken(MariaDBParser.ST_POLYGONFROMTEXT, 0); }
		public TerminalNode ST_POLYGONFROMWKB() { return getToken(MariaDBParser.ST_POLYGONFROMWKB, 0); }
		public TerminalNode ST_SRID() { return getToken(MariaDBParser.ST_SRID, 0); }
		public TerminalNode ST_STARTPOINT() { return getToken(MariaDBParser.ST_STARTPOINT, 0); }
		public TerminalNode ST_SYMDIFFERENCE() { return getToken(MariaDBParser.ST_SYMDIFFERENCE, 0); }
		public TerminalNode ST_TOUCHES() { return getToken(MariaDBParser.ST_TOUCHES, 0); }
		public TerminalNode ST_UNION() { return getToken(MariaDBParser.ST_UNION, 0); }
		public TerminalNode ST_WITHIN() { return getToken(MariaDBParser.ST_WITHIN, 0); }
		public TerminalNode ST_X() { return getToken(MariaDBParser.ST_X, 0); }
		public TerminalNode ST_Y() { return getToken(MariaDBParser.ST_Y, 0); }
		public TerminalNode SUBDATE() { return getToken(MariaDBParser.SUBDATE, 0); }
		public TerminalNode SUBSTRING_INDEX() { return getToken(MariaDBParser.SUBSTRING_INDEX, 0); }
		public TerminalNode SUBTIME() { return getToken(MariaDBParser.SUBTIME, 0); }
		public TerminalNode SYSTEM_USER() { return getToken(MariaDBParser.SYSTEM_USER, 0); }
		public TerminalNode TAN() { return getToken(MariaDBParser.TAN, 0); }
		public TerminalNode TIME() { return getToken(MariaDBParser.TIME, 0); }
		public TerminalNode TIMEDIFF() { return getToken(MariaDBParser.TIMEDIFF, 0); }
		public TerminalNode TIMESTAMP() { return getToken(MariaDBParser.TIMESTAMP, 0); }
		public TerminalNode TIMESTAMPADD() { return getToken(MariaDBParser.TIMESTAMPADD, 0); }
		public TerminalNode TIMESTAMPDIFF() { return getToken(MariaDBParser.TIMESTAMPDIFF, 0); }
		public TerminalNode TIME_FORMAT() { return getToken(MariaDBParser.TIME_FORMAT, 0); }
		public TerminalNode TIME_TO_SEC() { return getToken(MariaDBParser.TIME_TO_SEC, 0); }
		public TerminalNode TOUCHES() { return getToken(MariaDBParser.TOUCHES, 0); }
		public TerminalNode TO_BASE64() { return getToken(MariaDBParser.TO_BASE64, 0); }
		public TerminalNode TO_DAYS() { return getToken(MariaDBParser.TO_DAYS, 0); }
		public TerminalNode TO_SECONDS() { return getToken(MariaDBParser.TO_SECONDS, 0); }
		public TerminalNode UCASE() { return getToken(MariaDBParser.UCASE, 0); }
		public TerminalNode UNCOMPRESS() { return getToken(MariaDBParser.UNCOMPRESS, 0); }
		public TerminalNode UNCOMPRESSED_LENGTH() { return getToken(MariaDBParser.UNCOMPRESSED_LENGTH, 0); }
		public TerminalNode UNHEX() { return getToken(MariaDBParser.UNHEX, 0); }
		public TerminalNode UNIX_TIMESTAMP() { return getToken(MariaDBParser.UNIX_TIMESTAMP, 0); }
		public TerminalNode UPDATEXML() { return getToken(MariaDBParser.UPDATEXML, 0); }
		public TerminalNode UPPER() { return getToken(MariaDBParser.UPPER, 0); }
		public TerminalNode UUID() { return getToken(MariaDBParser.UUID, 0); }
		public TerminalNode UUID_SHORT() { return getToken(MariaDBParser.UUID_SHORT, 0); }
		public TerminalNode VALIDATE_PASSWORD_STRENGTH() { return getToken(MariaDBParser.VALIDATE_PASSWORD_STRENGTH, 0); }
		public TerminalNode VERSION() { return getToken(MariaDBParser.VERSION, 0); }
		public TerminalNode VISIBLE() { return getToken(MariaDBParser.VISIBLE, 0); }
		public TerminalNode WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS() { return getToken(MariaDBParser.WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS, 0); }
		public TerminalNode WEEK() { return getToken(MariaDBParser.WEEK, 0); }
		public TerminalNode WEEKDAY() { return getToken(MariaDBParser.WEEKDAY, 0); }
		public TerminalNode WEEKOFYEAR() { return getToken(MariaDBParser.WEEKOFYEAR, 0); }
		public TerminalNode WEIGHT_STRING() { return getToken(MariaDBParser.WEIGHT_STRING, 0); }
		public TerminalNode WITHIN() { return getToken(MariaDBParser.WITHIN, 0); }
		public TerminalNode YEAR() { return getToken(MariaDBParser.YEAR, 0); }
		public TerminalNode YEARWEEK() { return getToken(MariaDBParser.YEARWEEK, 0); }
		public TerminalNode Y_FUNCTION() { return getToken(MariaDBParser.Y_FUNCTION, 0); }
		public TerminalNode X_FUNCTION() { return getToken(MariaDBParser.X_FUNCTION, 0); }
		public TerminalNode JSON_ARRAY() { return getToken(MariaDBParser.JSON_ARRAY, 0); }
		public TerminalNode JSON_OBJECT() { return getToken(MariaDBParser.JSON_OBJECT, 0); }
		public TerminalNode JSON_QUOTE() { return getToken(MariaDBParser.JSON_QUOTE, 0); }
		public TerminalNode JSON_CONTAINS() { return getToken(MariaDBParser.JSON_CONTAINS, 0); }
		public TerminalNode JSON_CONTAINS_PATH() { return getToken(MariaDBParser.JSON_CONTAINS_PATH, 0); }
		public TerminalNode JSON_EXTRACT() { return getToken(MariaDBParser.JSON_EXTRACT, 0); }
		public TerminalNode JSON_KEYS() { return getToken(MariaDBParser.JSON_KEYS, 0); }
		public TerminalNode JSON_OVERLAPS() { return getToken(MariaDBParser.JSON_OVERLAPS, 0); }
		public TerminalNode JSON_SEARCH() { return getToken(MariaDBParser.JSON_SEARCH, 0); }
		public TerminalNode JSON_VALUE() { return getToken(MariaDBParser.JSON_VALUE, 0); }
		public TerminalNode JSON_ARRAY_APPEND() { return getToken(MariaDBParser.JSON_ARRAY_APPEND, 0); }
		public TerminalNode JSON_ARRAY_INSERT() { return getToken(MariaDBParser.JSON_ARRAY_INSERT, 0); }
		public TerminalNode JSON_INSERT() { return getToken(MariaDBParser.JSON_INSERT, 0); }
		public TerminalNode JSON_MERGE() { return getToken(MariaDBParser.JSON_MERGE, 0); }
		public TerminalNode JSON_MERGE_PATCH() { return getToken(MariaDBParser.JSON_MERGE_PATCH, 0); }
		public TerminalNode JSON_MERGE_PRESERVE() { return getToken(MariaDBParser.JSON_MERGE_PRESERVE, 0); }
		public TerminalNode JSON_REMOVE() { return getToken(MariaDBParser.JSON_REMOVE, 0); }
		public TerminalNode JSON_REPLACE() { return getToken(MariaDBParser.JSON_REPLACE, 0); }
		public TerminalNode JSON_SET() { return getToken(MariaDBParser.JSON_SET, 0); }
		public TerminalNode JSON_UNQUOTE() { return getToken(MariaDBParser.JSON_UNQUOTE, 0); }
		public TerminalNode JSON_DEPTH() { return getToken(MariaDBParser.JSON_DEPTH, 0); }
		public TerminalNode JSON_LENGTH() { return getToken(MariaDBParser.JSON_LENGTH, 0); }
		public TerminalNode JSON_TYPE() { return getToken(MariaDBParser.JSON_TYPE, 0); }
		public TerminalNode JSON_VALID() { return getToken(MariaDBParser.JSON_VALID, 0); }
		public TerminalNode JSON_TABLE() { return getToken(MariaDBParser.JSON_TABLE, 0); }
		public TerminalNode JSON_SCHEMA_VALID() { return getToken(MariaDBParser.JSON_SCHEMA_VALID, 0); }
		public TerminalNode JSON_SCHEMA_VALIDATION_REPORT() { return getToken(MariaDBParser.JSON_SCHEMA_VALIDATION_REPORT, 0); }
		public TerminalNode JSON_PRETTY() { return getToken(MariaDBParser.JSON_PRETTY, 0); }
		public TerminalNode JSON_STORAGE_FREE() { return getToken(MariaDBParser.JSON_STORAGE_FREE, 0); }
		public TerminalNode JSON_STORAGE_SIZE() { return getToken(MariaDBParser.JSON_STORAGE_SIZE, 0); }
		public TerminalNode JSON_ARRAYAGG() { return getToken(MariaDBParser.JSON_ARRAYAGG, 0); }
		public TerminalNode JSON_OBJECTAGG() { return getToken(MariaDBParser.JSON_OBJECTAGG, 0); }
		public TerminalNode LASTVAL() { return getToken(MariaDBParser.LASTVAL, 0); }
		public TerminalNode NEXTVAL() { return getToken(MariaDBParser.NEXTVAL, 0); }
		public TerminalNode SETVAL() { return getToken(MariaDBParser.SETVAL, 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 MariaDBParserListener ) ((MariaDBParserListener)listener).enterFunctionNameBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MariaDBParserListener ) ((MariaDBParserListener)listener).exitFunctionNameBase(this);
		}
	}

	public final FunctionNameBaseContext functionNameBase() throws RecognitionException {
		FunctionNameBaseContext _localctx = new FunctionNameBaseContext(_ctx, getState());
		enterRule(_localctx, 728, RULE_functionNameBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7617);
			_la = _input.LA(1);
			if ( !(_la==DATABASE || ((((_la - 97)) & ~0x3f) == 0 && ((1L << (_la - 97)) & ((1L << (LEFT - 97)) | (1L << (RIGHT - 97)) | (1L << (SCHEMA - 97)))) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & ((1L << (DATE - 217)) | (1L << (TIME - 217)) | (1L << (TIMESTAMP - 217)) | (1L << (YEAR - 217)) | (1L << (JSON_ARRAY - 217)) | (1L << (JSON_ARRAYAGG - 217)) | (1L << (JSON_ARRAY_APPEND - 217)) | (1L << (JSON_ARRAY_INSERT - 217)) | (1L << (JSON_CONTAINS - 217)) | (1L << (JSON_CONTAINS_PATH - 217)) | (1L << (JSON_DEPTH - 217)) | (1L << (JSON_EXTRACT - 217)) | (1L << (JSON_INSERT - 217)) | (1L << (JSON_KEYS - 217)) | (1L << (JSON_LENGTH - 217)) | (1L << (JSON_MERGE - 217)) | (1L << (JSON_MERGE_PATCH - 217)) | (1L << (JSON_MERGE_PRESERVE - 217)) | (1L << (JSON_OBJECT - 217)) | (1L << (JSON_OBJECTAGG - 217)) | (1L << (JSON_OVERLAPS - 217)) | (1L << (JSON_PRETTY - 217)) | (1L << (JSON_QUOTE - 217)) | (1L << (JSON_REMOVE - 217)) | (1L << (JSON_REPLACE - 217)) | (1L << (JSON_SCHEMA_VALID - 217)) | (1L << (JSON_SCHEMA_VALIDATION_REPORT - 217)) | (1L << (JSON_SEARCH - 217)) | (1L << (JSON_SET - 217)) | (1L << (JSON_STORAGE_FREE - 217)) | (1L << (JSON_STORAGE_SIZE - 217)) | (1L << (JSON_TABLE - 217)) | (1L << (JSON_TYPE - 217)) | (1L << (JSON_UNQUOTE - 217)))) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & ((1L << (JSON_VALID - 281)) | (1L << (JSON_VALUE - 281)) | (1L << (COUNT - 281)) | (1L << (CUME_DIST - 281)) | (1L << (DENSE_RANK - 281)) | (1L << (FIRST_VALUE - 281)) | (1L << (LAG - 281)) | (1L << (LAST_VALUE - 281)) | (1L << (LEAD - 281)) | (1L << (NTILE - 281)) | (1L << (NTH_VALUE - 281)) | (1L << (PERCENT_RANK - 281)) | (1L << (RANK - 281)) | (1L << (ROW_NUMBER - 281)) | (1L << (POSITION - 281)))) != 0) || _la==INVISIBLE || ((((_la - 677)) & ~0x3f) == 0 && ((1L << (_la - 677)) & ((1L << (VISIBLE - 677)) | (1L << (QUARTER - 677)) | (1L << (MONTH - 677)) | (1L << (DAY - 677)) | (1L << (HOUR - 677)) | (1L << (MINUTE - 677)) | (1L << (WEEK - 677)) | (1L << (SECOND - 677)) | (1L << (MICROSECOND - 677)))) != 0) || _la==SESSION_VARIABLES_ADMIN || ((((_la - 810)) & ~0x3f) == 0 && ((1L << (_la - 810)) & ((1L << (GEOMETRYCOLLECTION - 810)) | (1L << (LINESTRING - 810)) | (1L << (MULTILINESTRING - 810)) | (1L << (MULTIPOINT - 810)) | (1L << (MULTIPOLYGON - 810)) | (1L << (POINT - 810)) | (1L << (POLYGON - 810)) | (1L << (ABS - 810)) | (1L << (ACOS - 810)) | (1L << (ADDDATE - 810)) | (1L << (ADDTIME - 810)) | (1L << (AES_DECRYPT - 810)) | (1L << (AES_ENCRYPT - 810)) | (1L << (AREA - 810)) | (1L << (ASBINARY - 810)) | (1L << (ASIN - 810)) | (1L << (ASTEXT - 810)) | (1L << (ASWKB - 810)) | (1L << (ASWKT - 810)) | (1L << (ASYMMETRIC_DECRYPT - 810)) | (1L << (ASYMMETRIC_DERIVE - 810)) | (1L << (ASYMMETRIC_ENCRYPT - 810)) | (1L << (ASYMMETRIC_SIGN - 810)) | (1L << (ASYMMETRIC_VERIFY - 810)) | (1L << (ATAN - 810)) | (1L << (ATAN2 - 810)) | (1L << (BENCHMARK - 810)) | (1L << (BIN - 810)) | (1L << (BIT_COUNT - 810)) | (1L << (BIT_LENGTH - 810)) | (1L << (BUFFER - 810)) | (1L << (CEIL - 810)) | (1L << (CEILING - 810)) | (1L << (CENTROID - 810)) | (1L << (CHARACTER_LENGTH - 810)) | (1L << (CHARSET - 810)) | (1L << (CHAR_LENGTH - 810)) | (1L << (COERCIBILITY - 810)) | (1L << (COLLATION - 810)) | (1L << (COMPRESS - 810)) | (1L << (CONCAT - 810)) | (1L << (CONCAT_WS - 810)) | (1L << (CONNECTION_ID - 810)) | (1L << (CONV - 810)) | (1L << (CONVERT_TZ - 810)) | (1L << (COS - 810)) | (1L << (COT - 810)) | (1L << (CRC32 - 810)) | (1L << (CREATE_ASYMMETRIC_PRIV_KEY - 810)) | (1L << (CREATE_ASYMMETRIC_PUB_KEY - 810)) | (1L << (CREATE_DH_PARAMETERS - 810)) | (1L << (CREATE_DIGEST - 810)) | (1L << (CROSSES - 810)) | (1L << (DATEDIFF - 810)) | (1L << (DATE_FORMAT - 810)) | (1L << (DAYNAME - 810)) | (1L << (DAYOFMONTH - 810)) | (1L << (DAYOFWEEK - 810)) | (1L << (DAYOFYEAR - 810)) | (1L << (DECODE - 810)) | (1L << (DEGREES - 810)))) != 0) || ((((_la - 874)) & ~0x3f) == 0 && ((1L << (_la - 874)) & ((1L << (DES_DECRYPT - 874)) | (1L << (DES_ENCRYPT - 874)) | (1L << (DIMENSION - 874)) | (1L << (DISJOINT - 874)) | (1L << (ELT - 874)) | (1L << (ENCODE - 874)) | (1L << (ENCRYPT - 874)) | (1L << (ENDPOINT - 874)) | (1L << (ENVELOPE - 874)) | (1L << (EQUALS - 874)) | (1L << (EXP - 874)) | (1L << (EXPORT_SET - 874)) | (1L << (EXTERIORRING - 874)) | (1L << (EXTRACTVALUE - 874)) | (1L << (FIELD - 874)) | (1L << (FIND_IN_SET - 874)) | (1L << (FLOOR - 874)) | (1L << (FORMAT - 874)) | (1L << (FOUND_ROWS - 874)) | (1L << (FROM_BASE64 - 874)) | (1L << (FROM_DAYS - 874)) | (1L << (FROM_UNIXTIME - 874)) | (1L << (GEOMCOLLFROMTEXT - 874)) | (1L << (GEOMCOLLFROMWKB - 874)) | (1L << (GEOMETRYCOLLECTIONFROMTEXT - 874)) | (1L << (GEOMETRYCOLLECTIONFROMWKB - 874)) | (1L << (GEOMETRYFROMTEXT - 874)) | (1L << (GEOMETRYFROMWKB - 874)) | (1L << (GEOMETRYN - 874)) | (1L << (GEOMETRYTYPE - 874)) | (1L << (GEOMFROMTEXT - 874)) | (1L << (GEOMFROMWKB - 874)) | (1L << (GET_FORMAT - 874)) | (1L << (GET_LOCK - 874)) | (1L << (GLENGTH - 874)) | (1L << (GREATEST - 874)) | (1L << (GTID_SUBSET - 874)) | (1L << (GTID_SUBTRACT - 874)) | (1L << (HEX - 874)) | (1L << (IFNULL - 874)) | (1L << (INET6_ATON - 874)) | (1L << (INET6_NTOA - 874)) | (1L << (INET_ATON - 874)) | (1L << (INET_NTOA - 874)) | (1L << (INSTR - 874)) | (1L << (INTERIORRINGN - 874)) | (1L << (INTERSECTS - 874)) | (1L << (ISCLOSED - 874)) | (1L << (ISEMPTY - 874)) | (1L << (ISNULL - 874)) | (1L << (ISSIMPLE - 874)) | (1L << (IS_FREE_LOCK - 874)) | (1L << (IS_IPV4 - 874)) | (1L << (IS_IPV4_COMPAT - 874)) | (1L << (IS_IPV4_MAPPED - 874)) | (1L << (IS_IPV6 - 874)) | (1L << (IS_USED_LOCK - 874)) | (1L << (LAST_INSERT_ID - 874)) | (1L << (LCASE - 874)) | (1L << (LEAST - 874)) | (1L << (LENGTH - 874)) | (1L << (LINEFROMTEXT - 874)) | (1L << (LINEFROMWKB - 874)))) != 0) || ((((_la - 938)) & ~0x3f) == 0 && ((1L << (_la - 938)) & ((1L << (LINESTRINGFROMTEXT - 938)) | (1L << (LINESTRINGFROMWKB - 938)) | (1L << (LN - 938)) | (1L << (LOAD_FILE - 938)) | (1L << (LOCATE - 938)) | (1L << (LOG - 938)) | (1L << (LOG10 - 938)) | (1L << (LOG2 - 938)) | (1L << (LOWER - 938)) | (1L << (LPAD - 938)) | (1L << (LTRIM - 938)) | (1L << (MAKEDATE - 938)) | (1L << (MAKETIME - 938)) | (1L << (MAKE_SET - 938)) | (1L << (MASTER_POS_WAIT - 938)) | (1L << (MBRCONTAINS - 938)) | (1L << (MBRDISJOINT - 938)) | (1L << (MBREQUAL - 938)) | (1L << (MBRINTERSECTS - 938)) | (1L << (MBROVERLAPS - 938)) | (1L << (MBRTOUCHES - 938)) | (1L << (MBRWITHIN - 938)) | (1L << (MD5 - 938)) | (1L << (MLINEFROMTEXT - 938)) | (1L << (MLINEFROMWKB - 938)) | (1L << (MONTHNAME - 938)) | (1L << (MPOINTFROMTEXT - 938)) | (1L << (MPOINTFROMWKB - 938)) | (1L << (MPOLYFROMTEXT - 938)) | (1L << (MPOLYFROMWKB - 938)) | (1L << (MULTILINESTRINGFROMTEXT - 938)) | (1L << (MULTILINESTRINGFROMWKB - 938)) | (1L << (MULTIPOINTFROMTEXT - 938)) | (1L << (MULTIPOINTFROMWKB - 938)) | (1L << (MULTIPOLYGONFROMTEXT - 938)) | (1L << (MULTIPOLYGONFROMWKB - 938)) | (1L << (NAME_CONST - 938)) | (1L << (NULLIF - 938)) | (1L << (NUMGEOMETRIES - 938)) | (1L << (NUMINTERIORRINGS - 938)) | (1L << (NUMPOINTS - 938)) | (1L << (OCT - 938)) | (1L << (OCTET_LENGTH - 938)) | (1L << (ORD - 938)) | (1L << (OVERLAPS - 938)) | (1L << (PERIOD_ADD - 938)) | (1L << (PERIOD_DIFF - 938)) | (1L << (PI - 938)) | (1L << (POINTFROMTEXT - 938)) | (1L << (POINTFROMWKB - 938)) | (1L << (POINTN - 938)) | (1L << (POLYFROMTEXT - 938)) | (1L << (POLYFROMWKB - 938)) | (1L << (POLYGONFROMTEXT - 938)) | (1L << (POLYGONFROMWKB - 938)) | (1L << (POW - 938)) | (1L << (POWER - 938)) | (1L << (QUOTE - 938)) | (1L << (RADIANS - 938)) | (1L << (RAND - 938)) | (1L << (RANDOM_BYTES - 938)) | (1L << (RELEASE_LOCK - 938)) | (1L << (REVERSE - 938)) | (1L << (ROUND - 938)))) != 0) || ((((_la - 1002)) & ~0x3f) == 0 && ((1L << (_la - 1002)) & ((1L << (ROW_COUNT - 1002)) | (1L << (RPAD - 1002)) | (1L << (RTRIM - 1002)) | (1L << (SEC_TO_TIME - 1002)) | (1L << (SESSION_USER - 1002)) | (1L << (SHA - 1002)) | (1L << (SHA1 - 1002)) | (1L << (SHA2 - 1002)) | (1L << (SIGN - 1002)) | (1L << (SIN - 1002)) | (1L << (SLEEP - 1002)) | (1L << (SOUNDEX - 1002)) | (1L << (SQL_THREAD_WAIT_AFTER_GTIDS - 1002)) | (1L << (SQRT - 1002)) | (1L << (SRID - 1002)) | (1L << (STARTPOINT - 1002)) | (1L << (STRCMP - 1002)) | (1L << (STR_TO_DATE - 1002)) | (1L << (ST_AREA - 1002)) | (1L << (ST_ASBINARY - 1002)) | (1L << (ST_ASTEXT - 1002)) | (1L << (ST_ASWKB - 1002)) | (1L << (ST_ASWKT - 1002)) | (1L << (ST_BUFFER - 1002)) | (1L << (ST_CENTROID - 1002)) | (1L << (ST_CONTAINS - 1002)) | (1L << (ST_CROSSES - 1002)) | (1L << (ST_DIFFERENCE - 1002)) | (1L << (ST_DIMENSION - 1002)) | (1L << (ST_DISJOINT - 1002)) | (1L << (ST_DISTANCE - 1002)) | (1L << (ST_ENDPOINT - 1002)) | (1L << (ST_ENVELOPE - 1002)) | (1L << (ST_EQUALS - 1002)) | (1L << (ST_EXTERIORRING - 1002)) | (1L << (ST_GEOMCOLLFROMTEXT - 1002)) | (1L << (ST_GEOMCOLLFROMTXT - 1002)) | (1L << (ST_GEOMCOLLFROMWKB - 1002)) | (1L << (ST_GEOMETRYCOLLECTIONFROMTEXT - 1002)) | (1L << (ST_GEOMETRYCOLLECTIONFROMWKB - 1002)) | (1L << (ST_GEOMETRYFROMTEXT - 1002)) | (1L << (ST_GEOMETRYFROMWKB - 1002)) | (1L << (ST_GEOMETRYN - 1002)) | (1L << (ST_GEOMETRYTYPE - 1002)) | (1L << (ST_GEOMFROMTEXT - 1002)) | (1L << (ST_GEOMFROMWKB - 1002)) | (1L << (ST_INTERIORRINGN - 1002)) | (1L << (ST_INTERSECTION - 1002)) | (1L << (ST_INTERSECTS - 1002)) | (1L << (ST_ISCLOSED - 1002)) | (1L << (ST_ISEMPTY - 1002)) | (1L << (ST_ISSIMPLE - 1002)) | (1L << (ST_LINEFROMTEXT - 1002)) | (1L << (ST_LINEFROMWKB - 1002)) | (1L << (ST_LINESTRINGFROMTEXT - 1002)) | (1L << (ST_LINESTRINGFROMWKB - 1002)) | (1L << (ST_NUMGEOMETRIES - 1002)) | (1L << (ST_NUMINTERIORRING - 1002)) | (1L << (ST_NUMINTERIORRINGS - 1002)) | (1L << (ST_NUMPOINTS - 1002)) | (1L << (ST_OVERLAPS - 1002)) | (1L << (ST_POINTFROMTEXT - 1002)))) != 0) || ((((_la - 1066)) & ~0x3f) == 0 && ((1L << (_la - 1066)) & ((1L << (ST_POINTFROMWKB - 1066)) | (1L << (ST_POINTN - 1066)) | (1L << (ST_POLYFROMTEXT - 1066)) | (1L << (ST_POLYFROMWKB - 1066)) | (1L << (ST_POLYGONFROMTEXT - 1066)) | (1L << (ST_POLYGONFROMWKB - 1066)) | (1L << (ST_SRID - 1066)) | (1L << (ST_STARTPOINT - 1066)) | (1L << (ST_SYMDIFFERENCE - 1066)) | (1L << (ST_TOUCHES - 1066)) | (1L << (ST_UNION - 1066)) | (1L << (ST_WITHIN - 1066)) | (1L << (ST_X - 1066)) | (1L << (ST_Y - 1066)) | (1L << (SUBDATE - 1066)) | (1L << (SUBSTRING_INDEX - 1066)) | (1L << (SUBTIME - 1066)) | (1L << (SYSTEM_USER - 1066)) | (1L << (TAN - 1066)) | (1L << (TIMEDIFF - 1066)) | (1L << (TIMESTAMPADD - 1066)) | (1L << (TIMESTAMPDIFF - 1066)) | (1L << (TIME_FORMAT - 1066)) | (1L << (TIME_TO_SEC - 1066)) | (1L << (TOUCHES - 1066)) | (1L << (TO_BASE64 - 1066)) | (1L << (TO_DAYS - 1066)) | (1L << (TO_SECONDS - 1066)) | (1L << (UCASE - 1066)) | (1L << (UNCOMPRESS - 1066)) | (1L << (UNCOMPRESSED_LENGTH - 1066)) | (1L << (UNHEX - 1066)) | (1L << (UNIX_TIMESTAMP - 1066)) | (1L << (UPDATEXML - 1066)) | (1L << (UPPER - 1066)) | (1L << (UUID - 1066)) | (1L << (UUID_SHORT - 1066)) | (1L << (VALIDATE_PASSWORD_STRENGTH - 1066)) | (1L << (VERSION - 1066)) | (1L << (WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS - 1066)) | (1L << (WEEKDAY - 1066)) | (1L << (WEEKOFYEAR - 1066)) | (1L << (WEIGHT_STRING - 1066)) | (1L << (WITHIN - 1066)) | (1L << (YEARWEEK - 1066)) | (1L << (Y_FUNCTION - 1066)) | (1L << (X_FUNCTION - 1066)) | (1L << (LASTVAL - 1066)) | (1L << (NEXTVAL - 1066)) | (1L << (SETVAL - 1066)))) != 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 349:
			return expression_sempred((ExpressionContext)_localctx, predIndex);
		case 350:
			return predicate_sempred((PredicateContext)_localctx, predIndex);
		case 351:
			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, 3);
		case 11:
			return precpred(_ctx, 2);
		case 12:
			return precpred(_ctx, 1);
		case 13:
			return precpred(_ctx, 13);
		}
		return true;
	}

	private static final String _serializedATNSegment0 =
		"\u0004\u0001\u049e\u1dc4\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\u0002\u0169\u0007\u0169\u0002\u016a\u0007"+
		"\u016a\u0002\u016b\u0007\u016b\u0002\u016c\u0007\u016c\u0001\u0000\u0003"+
		"\u0000\u02dc\b\u0000\u0001\u0000\u0001\u0000\u0003\u0000\u02e0\b\u0000"+
		"\u0001\u0000\u0001\u0000\u0001\u0001\u0001\u0001\u0001\u0001\u0003\u0001"+
		"\u02e7\b\u0001\u0001\u0001\u0003\u0001\u02ea\b\u0001\u0001\u0001\u0005"+
		"\u0001\u02ed\b\u0001\n\u0001\f\u0001\u02f0\t\u0001\u0001\u0001\u0001\u0001"+
		"\u0001\u0001\u0003\u0001\u02f5\b\u0001\u0001\u0001\u0003\u0001\u02f8\b"+
		"\u0001\u0001\u0001\u0003\u0001\u02fb\b\u0001\u0001\u0002\u0003\u0002\u02fe"+
		"\b\u0002\u0001\u0002\u0001\u0002\u0001\u0002\u0001\u0002\u0001\u0002\u0001"+
		"\u0002\u0001\u0002\u0003\u0002\u0307\b\u0002\u0001\u0003\u0001\u0003\u0001"+
		"\u0003\u0001\u0003\u0001\u0003\u0001\u0003\u0001\u0003\u0001\u0003\u0001"+
		"\u0003\u0005\u0003\u0312\b\u0003\n\u0003\f\u0003\u0315\t\u0003\u0001\u0003"+
		"\u0001\u0003\u0001\u0004\u0001\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\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\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"+
		"\u0001\u0005\u0001\u0005\u0003\u0005\u0344\b\u0005\u0001\u0006\u0001\u0006"+
		"\u0001\u0006\u0001\u0006\u0001\u0006\u0001\u0006\u0001\u0006\u0001\u0006"+
		"\u0001\u0006\u0001\u0006\u0001\u0006\u0003\u0006\u0351\b\u0006\u0001\u0007"+
		"\u0001\u0007\u0001\u0007\u0001\u0007\u0001\u0007\u0001\u0007\u0001\u0007"+
		"\u0001\u0007\u0001\u0007\u0003\u0007\u035c\b\u0007\u0001\b\u0001\b\u0001"+
		"\b\u0001\b\u0001\b\u0001\b\u0001\b\u0001\b\u0001\b\u0001\b\u0001\b\u0001"+
		"\b\u0001\b\u0001\b\u0001\b\u0003\b\u036d\b\b\u0001\t\u0001\t\u0001\t\u0003"+
		"\t\u0372\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\u0003\n\u0381\b\n\u0001\u000b"+
		"\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b"+
		"\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b"+
		"\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b"+
		"\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b"+
		"\u0001\u000b\u0003\u000b\u039d\b\u000b\u0001\f\u0001\f\u0001\f\u0001\f"+
		"\u0001\f\u0001\f\u0001\f\u0003\f\u03a6\b\f\u0001\r\u0001\r\u0001\r\u0003"+
		"\r\u03ab\b\r\u0001\r\u0001\r\u0005\r\u03af\b\r\n\r\f\r\u03b2\t\r\u0001"+
		"\u000e\u0001\u000e\u0003\u000e\u03b6\b\u000e\u0001\u000e\u0001\u000e\u0003"+
		"\u000e\u03ba\b\u000e\u0001\u000e\u0001\u000e\u0001\u000e\u0001\u000e\u0001"+
		"\u000e\u0001\u000e\u0001\u000e\u0003\u000e\u03c3\b\u000e\u0001\u000e\u0003"+
		"\u000e\u03c6\b\u000e\u0001\u000e\u0003\u000e\u03c9\b\u000e\u0001\u000e"+
		"\u0001\u000e\u0003\u000e\u03cd\b\u000e\u0001\u000e\u0001\u000e\u0001\u000e"+
		"\u0001\u000f\u0001\u000f\u0003\u000f\u03d4\b\u000f\u0001\u000f\u0003\u000f"+
		"\u03d7\b\u000f\u0001\u000f\u0003\u000f\u03da\b\u000f\u0001\u000f\u0001"+
		"\u000f\u0003\u000f\u03de\b\u000f\u0001\u000f\u0001\u000f\u0003\u000f\u03e2"+
		"\b\u000f\u0001\u000f\u0001\u000f\u0001\u000f\u0001\u000f\u0003\u000f\u03e8"+
		"\b\u000f\u0001\u000f\u0005\u000f\u03eb\b\u000f\n\u000f\f\u000f\u03ee\t"+
		"\u000f\u0001\u000f\u0001\u000f\u0003\u000f\u03f2\b\u000f\u0001\u000f\u0001"+
		"\u000f\u0001\u000f\u0003\u000f\u03f7\b\u000f\u0001\u000f\u0005\u000f\u03fa"+
		"\b\u000f\n\u000f\f\u000f\u03fd\t\u000f\u0001\u0010\u0001\u0010\u0001\u0010"+
		"\u0001\u0010\u0001\u0010\u0001\u0010\u0001\u0010\u0001\u0010\u0001\u0010"+
		"\u0003\u0010\u0408\b\u0010\u0001\u0010\u0003\u0010\u040b\b\u0010\u0001"+
		"\u0010\u0001\u0010\u0003\u0010\u040f\b\u0010\u0001\u0010\u0003\u0010\u0412"+
		"\b\u0010\u0001\u0010\u0001\u0010\u0003\u0010\u0416\b\u0010\u0001\u0010"+
		"\u0003\u0010\u0419\b\u0010\u0001\u0010\u0001\u0010\u0003\u0010\u041d\b"+
		"\u0010\u0001\u0010\u0003\u0010\u0420\b\u0010\u0001\u0010\u0003\u0010\u0423"+
		"\b\u0010\u0001\u0010\u0001\u0010\u0003\u0010\u0427\b\u0010\u0001\u0010"+
		"\u0003\u0010\u042a\b\u0010\u0001\u0010\u0001\u0010\u0003\u0010\u042e\b"+
		"\u0010\u0001\u0010\u0001\u0010\u0001\u0011\u0001\u0011\u0003\u0011\u0434"+
		"\b\u0011\u0001\u0011\u0003\u0011\u0437\b\u0011\u0001\u0011\u0001\u0011"+
		"\u0001\u0011\u0001\u0011\u0003\u0011\u043d\b\u0011\u0001\u0011\u0001\u0011"+
		"\u0005\u0011\u0441\b\u0011\n\u0011\f\u0011\u0444\t\u0011\u0001\u0011\u0001"+
		"\u0011\u0005\u0011\u0448\b\u0011\n\u0011\f\u0011\u044b\t\u0011\u0001\u0011"+
		"\u0001\u0011\u0001\u0012\u0001\u0012\u0003\u0012\u0451\b\u0012\u0001\u0012"+
		"\u0003\u0012\u0454\b\u0012\u0001\u0012\u0003\u0012\u0457\b\u0012\u0001"+
		"\u0012\u0001\u0012\u0003\u0012\u045b\b\u0012\u0001\u0012\u0001\u0012\u0001"+
		"\u0012\u0003\u0012\u0460\b\u0012\u0001\u0012\u0001\u0012\u0005\u0012\u0464"+
		"\b\u0012\n\u0012\f\u0012\u0467\t\u0012\u0001\u0012\u0001\u0012\u0001\u0012"+
		"\u0001\u0012\u0005\u0012\u046d\b\u0012\n\u0012\f\u0012\u0470\t\u0012\u0001"+
		"\u0012\u0001\u0012\u0003\u0012\u0474\b\u0012\u0001\u0013\u0001\u0013\u0001"+
		"\u0013\u0003\u0013\u0479\b\u0013\u0001\u0013\u0001\u0013\u0001\u0013\u0005"+
		"\u0013\u047e\b\u0013\n\u0013\f\u0013\u0481\t\u0013\u0001\u0014\u0001\u0014"+
		"\u0001\u0014\u0001\u0014\u0001\u0014\u0001\u0014\u0001\u0014\u0001\u0014"+
		"\u0001\u0014\u0001\u0014\u0001\u0014\u0001\u0014\u0005\u0014\u048f\b\u0014"+
		"\n\u0014\f\u0014\u0492\t\u0014\u0001\u0014\u0001\u0014\u0001\u0015\u0001"+
		"\u0015\u0003\u0015\u0498\b\u0015\u0001\u0015\u0003\u0015\u049b\b\u0015"+
		"\u0001\u0015\u0001\u0015\u0003\u0015\u049f\b\u0015\u0001\u0015\u0001\u0015"+
		"\u0001\u0015\u0001\u0015\u0001\u0015\u0001\u0015\u0001\u0015\u0001\u0015"+
		"\u0003\u0015\u04a9\b\u0015\u0001\u0015\u0001\u0015\u0003\u0015\u04ad\b"+
		"\u0015\u0001\u0015\u0003\u0015\u04b0\b\u0015\u0001\u0015\u0001\u0015\u0003"+
		"\u0015\u04b4\b\u0015\u0001\u0015\u0001\u0015\u0003\u0015\u04b8\b\u0015"+
		"\u0001\u0015\u0001\u0015\u0003\u0015\u04bc\b\u0015\u0001\u0015\u0005\u0015"+
		"\u04bf\b\u0015\n\u0015\f\u0015\u04c2\t\u0015\u0003\u0015\u04c4\b\u0015"+
		"\u0001\u0015\u0003\u0015\u04c7\b\u0015\u0001\u0015\u0003\u0015\u04ca\b"+
		"\u0015\u0001\u0015\u0003\u0015\u04cd\b\u0015\u0001\u0015\u0001\u0015\u0001"+
		"\u0015\u0001\u0015\u0003\u0015\u04d3\b\u0015\u0001\u0015\u0003\u0015\u04d6"+
		"\b\u0015\u0001\u0015\u0001\u0015\u0003\u0015\u04da\b\u0015\u0001\u0015"+
		"\u0001\u0015\u0001\u0015\u0001\u0015\u0003\u0015\u04e0\b\u0015\u0001\u0015"+
		"\u0005\u0015\u04e3\b\u0015\n\u0015\f\u0015\u04e6\t\u0015\u0003\u0015\u04e8"+
		"\b\u0015\u0001\u0015\u0003\u0015\u04eb\b\u0015\u0003\u0015\u04ed\b\u0015"+
		"\u0001\u0016\u0001\u0016\u0001\u0016\u0001\u0016\u0001\u0016\u0001\u0016"+
		"\u0001\u0016\u0001\u0016\u0001\u0016\u0003\u0016\u04f8\b\u0016\u0001\u0016"+
		"\u0001\u0016\u0003\u0016\u04fc\b\u0016\u0001\u0016\u0003\u0016\u04ff\b"+
		"\u0016\u0001\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\u050d\b\u0017\u0001\u0017\u0003\u0017\u0510\b\u0017"+
		"\u0001\u0017\u0001\u0017\u0003\u0017\u0514\b\u0017\u0001\u0017\u0003\u0017"+
		"\u0517\b\u0017\u0001\u0017\u0001\u0017\u0003\u0017\u051b\b\u0017\u0001"+
		"\u0017\u0003\u0017\u051e\b\u0017\u0001\u0017\u0001\u0017\u0003\u0017\u0522"+
		"\b\u0017\u0001\u0017\u0003\u0017\u0525\b\u0017\u0001\u0017\u0001\u0017"+
		"\u0003\u0017\u0529\b\u0017\u0001\u0017\u0003\u0017\u052c\b\u0017\u0001"+
		"\u0017\u0003\u0017\u052f\b\u0017\u0001\u0017\u0001\u0017\u0003\u0017\u0533"+
		"\b\u0017\u0001\u0017\u0003\u0017\u0536\b\u0017\u0001\u0017\u0001\u0017"+
		"\u0003\u0017\u053a\b\u0017\u0001\u0017\u0001\u0017\u0001\u0018\u0001\u0018"+
		"\u0003\u0018\u0540\b\u0018\u0001\u0018\u0003\u0018\u0543\b\u0018\u0001"+
		"\u0018\u0001\u0018\u0001\u0018\u0001\u0018\u0001\u0018\u0001\u0018\u0001"+
		"\u0018\u0001\u0018\u0001\u0018\u0001\u0018\u0001\u0018\u0003\u0018\u0550"+
		"\b\u0018\u0001\u0018\u0001\u0018\u0001\u0019\u0001\u0019\u0003\u0019\u0556"+
		"\b\u0019\u0001\u0019\u0001\u0019\u0001\u001a\u0001\u001a\u0001\u001a\u0001"+
		"\u001a\u0001\u001a\u0005\u001a\u055f\b\u001a\n\u001a\f\u001a\u0562\t\u001a"+
		"\u0001\u001a\u0001\u001a\u0003\u001a\u0566\b\u001a\u0001\u001a\u0001\u001a"+
		"\u0001\u001a\u0001\u001a\u0001\u001a\u0001\u001a\u0003\u001a\u056e\b\u001a"+
		"\u0001\u001b\u0001\u001b\u0001\u001c\u0001\u001c\u0001\u001d\u0001\u001d"+
		"\u0003\u001d\u0576\b\u001d\u0001\u001d\u0001\u001d\u0001\u001d\u0003\u001d"+
		"\u057b\b\u001d\u0001\u001d\u0003\u001d\u057e\b\u001d\u0001\u001d\u0001"+
		"\u001d\u0001\u001d\u0003\u001d\u0583\b\u001d\u0001\u001d\u0001\u001d\u0001"+
		"\u001d\u0001\u001d\u0001\u001d\u0001\u001d\u0003\u001d\u058b\b\u001d\u0001"+
		"\u001d\u0001\u001d\u0001\u001d\u0003\u001d\u0590\b\u001d\u0001\u001d\u0001"+
		"\u001d\u0001\u001d\u0001\u001d\u0003\u001d\u0596\b\u001d\u0001\u001d\u0001"+
		"\u001d\u0001\u001d\u0003\u001d\u059b\b\u001d\u0001\u001d\u0001\u001d\u0003"+
		"\u001d\u059f\b\u001d\u0003\u001d\u05a1\b\u001d\u0001\u001e\u0001\u001e"+
		"\u0003\u001e\u05a5\b\u001e\u0001\u001e\u0003\u001e\u05a8\b\u001e\u0001"+
		"\u001e\u0001\u001e\u0003\u001e\u05ac\b\u001e\u0001\u001e\u0001\u001e\u0001"+
		"\u001e\u0005\u001e\u05b1\b\u001e\n\u001e\f\u001e\u05b4\t\u001e\u0001\u001f"+
		"\u0001\u001f\u0003\u001f\u05b8\b\u001f\u0001\u001f\u0001\u001f\u0001\u001f"+
		"\u0003\u001f\u05bd\b\u001f\u0001\u001f\u0001\u001f\u0001\u001f\u0001\u001f"+
		"\u0001\u001f\u0001\u001f\u0003\u001f\u05c5\b\u001f\u0001\u001f\u0001\u001f"+
		"\u0001\u001f\u0001\u001f\u0001\u001f\u0001\u001f\u0003\u001f\u05cd\b\u001f"+
		"\u0001\u001f\u0001\u001f\u0001\u001f\u0003\u001f\u05d2\b\u001f\u0001\u001f"+
		"\u0001\u001f\u0001\u001f\u0001\u001f\u0001\u001f\u0001\u001f\u0003\u001f"+
		"\u05da\b\u001f\u0001\u001f\u0003\u001f\u05dd\b\u001f\u0001 \u0003 \u05e0"+
		"\b \u0001 \u0001 \u0003 \u05e4\b \u0001 \u0001 \u0003 \u05e8\b \u0001"+
		" \u0003 \u05eb\b \u0001 \u0001 \u0003 \u05ef\b \u0001 \u0001 \u0003 \u05f3"+
		"\b \u0001 \u0001 \u0003 \u05f7\b \u0001 \u0001 \u0001 \u0001 \u0003 \u05fd"+
		"\b \u0001 \u0003 \u0600\b \u0001!\u0001!\u0001!\u0001!\u0001!\u0003!\u0607"+
		"\b!\u0001\"\u0001\"\u0001\"\u0003\"\u060c\b\"\u0001#\u0001#\u0001#\u0001"+
		"#\u0001#\u0003#\u0613\b#\u0001$\u0001$\u0001$\u0005$\u0618\b$\n$\f$\u061b"+
		"\t$\u0001$\u0001$\u0001$\u0003$\u0620\b$\u0001$\u0001$\u0001$\u0001$\u0005"+
		"$\u0626\b$\n$\f$\u0629\t$\u0003$\u062b\b$\u0001$\u0001$\u0001$\u0005$"+
		"\u0630\b$\n$\f$\u0633\t$\u0003$\u0635\b$\u0003$\u0637\b$\u0001%\u0001"+
		"%\u0001%\u0001%\u0003%\u063d\b%\u0001&\u0001&\u0001&\u0001&\u0003&\u0643"+
		"\b&\u0001&\u0001&\u0001\'\u0001\'\u0001\'\u0001\'\u0001\'\u0001\'\u0001"+
		"\'\u0001\'\u0001\'\u0001\'\u0001\'\u0001\'\u0001\'\u0003\'\u0654\b\'\u0001"+
		"(\u0001(\u0001(\u0001(\u0001(\u0003(\u065b\b(\u0001)\u0001)\u0001)\u0001"+
		"*\u0001*\u0003*\u0662\b*\u0001*\u0001*\u0001*\u0001*\u0001*\u0001*\u0001"+
		"*\u0001*\u0001*\u0001*\u0003*\u066e\b*\u0001*\u0001*\u0001*\u0003*\u0673"+
		"\b*\u0001*\u0001*\u0001*\u0001*\u0001*\u0001*\u0001*\u0003*\u067c\b*\u0003"+
		"*\u067e\b*\u0001+\u0003+\u0681\b+\u0001+\u0001+\u0001+\u0001,\u0001,\u0001"+
		",\u0001-\u0001-\u0001-\u0001-\u0001-\u0003-\u068e\b-\u0001-\u0001-\u0001"+
		"-\u0001-\u0001-\u0001-\u0001-\u0001-\u0001-\u0001-\u0001-\u0003-\u069b"+
		"\b-\u0001-\u0001-\u0001-\u0003-\u06a0\b-\u0001.\u0001.\u0001.\u0001.\u0001"+
		".\u0001.\u0001.\u0001.\u0001.\u0001.\u0001.\u0001.\u0001.\u0001.\u0003"+
		".\u06b0\b.\u0001/\u0001/\u0001/\u0001/\u0005/\u06b6\b/\n/\f/\u06b9\t/"+
		"\u0001/\u0001/\u00010\u00010\u00010\u00010\u00010\u00030\u06c2\b0\u0001"+
		"1\u00011\u00051\u06c6\b1\n1\f1\u06c9\t1\u00012\u00012\u00012\u00012\u0001"+
		"2\u00012\u00012\u00012\u00012\u00032\u06d4\b2\u00012\u00032\u06d7\b2\u0001"+
		"2\u00012\u00012\u00032\u06dc\b2\u00012\u00012\u00012\u00012\u00012\u0001"+
		"2\u00012\u00012\u00012\u00012\u00012\u00032\u06e9\b2\u00012\u00012\u0001"+
		"2\u00012\u00012\u00032\u06f0\b2\u00012\u00012\u00012\u00012\u00012\u0003"+
		"2\u06f7\b2\u00032\u06f9\b2\u00012\u00012\u00012\u00012\u00012\u00032\u0700"+
		"\b2\u00013\u00013\u00033\u0704\b3\u00033\u0706\b3\u00013\u00013\u0001"+
		"3\u00033\u070b\b3\u00013\u00033\u070e\b3\u00013\u00013\u00053\u0712\b"+
		"3\n3\f3\u0715\t3\u00013\u00013\u00033\u0719\b3\u00033\u071b\b3\u00013"+
		"\u00013\u00033\u071f\b3\u00013\u00033\u0722\b3\u00013\u00033\u0725\b3"+
		"\u00013\u00013\u00053\u0729\b3\n3\f3\u072c\t3\u00013\u00013\u00033\u0730"+
		"\b3\u00033\u0732\b3\u00013\u00013\u00013\u00033\u0737\b3\u00013\u0001"+
		"3\u00013\u00013\u00013\u00033\u073e\b3\u00033\u0740\b3\u00013\u00013\u0001"+
		"3\u00013\u00013\u00033\u0747\b3\u00014\u00014\u00014\u00034\u074c\b4\u0001"+
		"4\u00014\u00034\u0750\b4\u00014\u00034\u0753\b4\u00015\u00015\u00015\u0001"+
		"5\u00015\u00015\u00035\u075b\b5\u00015\u00015\u00015\u00015\u00015\u0001"+
		"5\u00035\u0763\b5\u00035\u0765\b5\u00016\u00016\u00016\u00016\u00016\u0001"+
		"6\u00036\u076d\b6\u00017\u00017\u00037\u0771\b7\u00017\u00037\u0774\b"+
		"7\u00017\u00017\u00057\u0778\b7\n7\f7\u077b\t7\u00017\u00017\u00037\u077f"+
		"\b7\u00017\u00037\u0782\b7\u00017\u00017\u00057\u0786\b7\n7\f7\u0789\t"+
		"7\u00037\u078b\b7\u00018\u00018\u00038\u078f\b8\u00018\u00038\u0792\b"+
		"8\u00018\u00018\u00038\u0796\b8\u00018\u00018\u00018\u00038\u079b\b8\u0001"+
		"8\u00018\u00018\u00038\u07a0\b8\u00018\u00018\u00018\u00038\u07a5\b8\u0001"+
		"8\u00018\u00038\u07a9\b8\u00018\u00018\u00038\u07ad\b8\u00018\u00018\u0003"+
		"8\u07b1\b8\u00018\u00018\u00038\u07b5\b8\u00018\u00018\u00038\u07b9\b"+
		"8\u00018\u00018\u00038\u07bd\b8\u00018\u00018\u00018\u00038\u07c2\b8\u0001"+
		"8\u00018\u00018\u00038\u07c7\b8\u00018\u00018\u00018\u00038\u07cc\b8\u0001"+
		"8\u00018\u00018\u00018\u00038\u07d2\b8\u00018\u00018\u00018\u00038\u07d7"+
		"\b8\u00018\u00018\u00018\u00038\u07dc\b8\u00018\u00018\u00018\u00038\u07e1"+
		"\b8\u00018\u00018\u00018\u00018\u00038\u07e7\b8\u00018\u00018\u00018\u0003"+
		"8\u07ec\b8\u00018\u00018\u00018\u00038\u07f1\b8\u00018\u00018\u00018\u0001"+
		"8\u00038\u07f7\b8\u00018\u00018\u00018\u00038\u07fc\b8\u00018\u00018\u0001"+
		"8\u00038\u0801\b8\u00018\u00018\u00018\u00038\u0806\b8\u00018\u00018\u0001"+
		"8\u00038\u080b\b8\u00018\u00018\u00018\u00038\u0810\b8\u00018\u00018\u0001"+
		"8\u00038\u0815\b8\u00018\u00018\u00018\u00038\u081a\b8\u00018\u00018\u0001"+
		"8\u00018\u00018\u00038\u0821\b8\u00018\u00018\u00018\u00038\u0826\b8\u0001"+
		"8\u00018\u00018\u00038\u082b\b8\u00018\u00018\u00018\u00038\u0830\b8\u0001"+
		"8\u00018\u00038\u0834\b8\u00018\u00018\u00018\u00038\u0839\b8\u00018\u0001"+
		"8\u00018\u00018\u00018\u00018\u00038\u0841\b8\u00018\u00018\u00018\u0003"+
		"8\u0846\b8\u00018\u00018\u00018\u00018\u00038\u084c\b8\u00019\u00019\u0001"+
		":\u0001:\u0001:\u0001;\u0001;\u0001;\u0001;\u0001;\u0003;\u0858\b;\u0001"+
		";\u0001;\u0001;\u0001;\u0001;\u0003;\u085f\b;\u0003;\u0861\b;\u0001;\u0001"+
		";\u0001;\u0001;\u0005;\u0867\b;\n;\f;\u086a\t;\u0001;\u0001;\u0003;\u086e"+
		"\b;\u0001<\u0003<\u0871\b<\u0001<\u0001<\u0001<\u0001<\u0001<\u0001<\u0003"+
		"<\u0879\b<\u0001<\u0001<\u0001<\u0001<\u0003<\u087f\b<\u0001<\u0001<\u0001"+
		"<\u0001<\u0001<\u0001<\u0001<\u0001<\u0001<\u0001<\u0001<\u0001<\u0001"+
		"<\u0001<\u0003<\u088f\b<\u0001<\u0001<\u0001<\u0001<\u0001<\u0001<\u0001"+
		"<\u0001<\u0001<\u0001<\u0003<\u089b\b<\u0003<\u089d\b<\u0001=\u0003=\u08a0"+
		"\b=\u0001=\u0001=\u0001=\u0001=\u0001=\u0001=\u0003=\u08a8\b=\u0001=\u0001"+
		"=\u0001=\u0001=\u0003=\u08ae\b=\u0001=\u0001=\u0001=\u0001=\u0003=\u08b4"+
		"\b=\u0001>\u0001>\u0001>\u0001>\u0001>\u0001>\u0001>\u0001>\u0001>\u0005"+
		">\u08bf\b>\n>\f>\u08c2\t>\u0001>\u0001>\u0005>\u08c6\b>\n>\f>\u08c9\t"+
		">\u0001>\u0001>\u0001>\u0001>\u0005>\u08cf\b>\n>\f>\u08d2\t>\u0001>\u0001"+
		">\u0003>\u08d6\b>\u0001>\u0001>\u0001>\u0001>\u0001>\u0001>\u0001>\u0005"+
		">\u08df\b>\n>\f>\u08e2\t>\u0001>\u0001>\u0001>\u0001>\u0005>\u08e8\b>"+
		"\n>\f>\u08eb\t>\u0001>\u0001>\u0003>\u08ef\b>\u0001>\u0001>\u0001>\u0001"+
		">\u0001>\u0001>\u0001>\u0001>\u0005>\u08f9\b>\n>\f>\u08fc\t>\u0001>\u0001"+
		">\u0005>\u0900\b>\n>\f>\u0903\t>\u0001>\u0001>\u0001>\u0001>\u0005>\u0909"+
		"\b>\n>\f>\u090c\t>\u0001>\u0001>\u0003>\u0910\b>\u0001>\u0001>\u0001>"+
		"\u0001>\u0001>\u0001>\u0001>\u0001>\u0005>\u091a\b>\n>\f>\u091d\t>\u0001"+
		">\u0001>\u0005>\u0921\b>\n>\f>\u0924\t>\u0001>\u0001>\u0001>\u0001>\u0005"+
		">\u092a\b>\n>\f>\u092d\t>\u0001>\u0001>\u0003>\u0931\b>\u0001>\u0001>"+
		"\u0001>\u0005>\u0936\b>\n>\f>\u0939\t>\u0001>\u0001>\u0001>\u0001>\u0005"+
		">\u093f\b>\n>\f>\u0942\t>\u0001>\u0001>\u0003>\u0946\b>\u0003>\u0948\b"+
		">\u0001?\u0001?\u0001?\u0003?\u094d\b?\u0001@\u0001@\u0001@\u0001@\u0004"+
		"@\u0953\b@\u000b@\f@\u0954\u0001@\u0001@\u0001A\u0001A\u0001A\u0005A\u095c"+
		"\bA\nA\fA\u095f\tA\u0001B\u0003B\u0962\bB\u0001B\u0003B\u0965\bB\u0001"+
		"B\u0001B\u0003B\u0969\bB\u0001B\u0001B\u0001B\u0003B\u096e\bB\u0001B\u0001"+
		"B\u0001B\u0001B\u0003B\u0974\bB\u0001B\u0001B\u0001B\u0001B\u0003B\u097a"+
		"\bB\u0001B\u0001B\u0001B\u0003B\u097f\bB\u0001B\u0001B\u0001B\u0003B\u0984"+
		"\bB\u0001B\u0001B\u0001B\u0003B\u0989\bB\u0001B\u0001B\u0001B\u0003B\u098e"+
		"\bB\u0001B\u0003B\u0991\bB\u0001C\u0001C\u0001C\u0003C\u0996\bC\u0001"+
		"C\u0004C\u0999\bC\u000bC\fC\u099a\u0001C\u0001C\u0001C\u0001C\u0001C\u0001"+
		"C\u0001C\u0001C\u0003C\u09a5\bC\u0001D\u0001D\u0003D\u09a9\bD\u0001D\u0001"+
		"D\u0001D\u0001D\u0001D\u0003D\u09b0\bD\u0001D\u0001D\u0001D\u0003D\u09b5"+
		"\bD\u0001D\u0003D\u09b8\bD\u0001D\u0001D\u0001D\u0003D\u09bd\bD\u0001"+
		"D\u0003D\u09c0\bD\u0001D\u0001D\u0003D\u09c4\bD\u0001D\u0001D\u0003D\u09c8"+
		"\bD\u0001E\u0001E\u0001E\u0001E\u0005E\u09ce\bE\nE\fE\u09d1\tE\u0001F"+
		"\u0001F\u0001F\u0001F\u0001F\u0001F\u0001F\u0001G\u0001G\u0001G\u0001"+
		"G\u0001G\u0001G\u0001G\u0001G\u0001G\u0003G\u09e3\bG\u0001G\u0003G\u09e6"+
		"\bG\u0001G\u0003G\u09e9\bG\u0001G\u0001G\u0003G\u09ed\bG\u0001G\u0001"+
		"G\u0001H\u0001H\u0001H\u0001H\u0005H\u09f5\bH\nH\fH\u09f8\tH\u0001I\u0001"+
		"I\u0001I\u0001I\u0001I\u0001I\u0001I\u0001I\u0005I\u0a02\bI\nI\fI\u0a05"+
		"\tI\u0001I\u0001I\u0001J\u0001J\u0003J\u0a0b\bJ\u0001J\u0003J\u0a0e\b"+
		"J\u0001J\u0001J\u0003J\u0a12\bJ\u0001J\u0001J\u0003J\u0a16\bJ\u0001J\u0001"+
		"J\u0001J\u0005J\u0a1b\bJ\nJ\fJ\u0a1e\tJ\u0003J\u0a20\bJ\u0001J\u0003J"+
		"\u0a23\bJ\u0001K\u0001K\u0001K\u0001K\u0001K\u0001K\u0001K\u0001K\u0001"+
		"K\u0003K\u0a2e\bK\u0001K\u0003K\u0a31\bK\u0001K\u0001K\u0003K\u0a35\b"+
		"K\u0001K\u0001K\u0001L\u0001L\u0001L\u0001L\u0003L\u0a3d\bL\u0001L\u0003"+
		"L\u0a40\bL\u0001L\u0001L\u0001L\u0003L\u0a45\bL\u0001L\u0001L\u0001L\u0001"+
		"L\u0001L\u0001L\u0003L\u0a4d\bL\u0001L\u0001L\u0001L\u0001L\u0003L\u0a53"+
		"\bL\u0001L\u0001L\u0003L\u0a57\bL\u0001M\u0001M\u0001M\u0003M\u0a5c\b"+
		"M\u0001M\u0001M\u0004M\u0a60\bM\u000bM\fM\u0a61\u0001N\u0001N\u0003N\u0a66"+
		"\bN\u0001N\u0005N\u0a69\bN\nN\fN\u0a6c\tN\u0001N\u0001N\u0003N\u0a70\b"+
		"N\u0001N\u0003N\u0a73\bN\u0001N\u0001N\u0001N\u0001N\u0001N\u0003N\u0a7a"+
		"\bN\u0001N\u0001N\u0003N\u0a7e\bN\u0001N\u0003N\u0a81\bN\u0001N\u0001"+
		"N\u0001N\u0001N\u0001N\u0001N\u0001N\u0005N\u0a8a\bN\nN\fN\u0a8d\tN\u0001"+
		"N\u0001N\u0001N\u0001N\u0001N\u0003N\u0a94\bN\u0001N\u0003N\u0a97\bN\u0001"+
		"N\u0003N\u0a9a\bN\u0001N\u0001N\u0005N\u0a9e\bN\nN\fN\u0aa1\tN\u0001N"+
		"\u0001N\u0001N\u0003N\u0aa6\bN\u0003N\u0aa8\bN\u0001N\u0001N\u0001N\u0003"+
		"N\u0aad\bN\u0001N\u0003N\u0ab0\bN\u0001N\u0001N\u0005N\u0ab4\bN\nN\fN"+
		"\u0ab7\tN\u0001N\u0001N\u0001N\u0003N\u0abc\bN\u0003N\u0abe\bN\u0001N"+
		"\u0001N\u0003N\u0ac2\bN\u0001N\u0003N\u0ac5\bN\u0001N\u0003N\u0ac8\bN"+
		"\u0001N\u0003N\u0acb\bN\u0001N\u0001N\u0005N\u0acf\bN\nN\fN\u0ad2\tN\u0001"+
		"N\u0001N\u0001N\u0003N\u0ad7\bN\u0001N\u0003N\u0ada\bN\u0001N\u0001N\u0005"+
		"N\u0ade\bN\nN\fN\u0ae1\tN\u0001N\u0001N\u0001N\u0003N\u0ae6\bN\u0003N"+
		"\u0ae8\bN\u0001N\u0001N\u0001N\u0003N\u0aed\bN\u0001N\u0003N\u0af0\bN"+
		"\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0003N\u0af8\bN\u0003N\u0afa"+
		"\bN\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0003N\u0b03\bN\u0001"+
		"N\u0001N\u0001N\u0003N\u0b08\bN\u0001N\u0001N\u0001N\u0001N\u0001N\u0001"+
		"N\u0003N\u0b10\bN\u0001N\u0001N\u0003N\u0b14\bN\u0001N\u0003N\u0b17\b"+
		"N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0003N\u0b1f\bN\u0001N\u0001"+
		"N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0003N\u0b29\bN\u0001N\u0001"+
		"N\u0001N\u0003N\u0b2e\bN\u0001N\u0003N\u0b31\bN\u0001N\u0001N\u0001N\u0001"+
		"N\u0001N\u0003N\u0b38\bN\u0001N\u0001N\u0003N\u0b3c\bN\u0001N\u0003N\u0b3f"+
		"\bN\u0001N\u0001N\u0003N\u0b43\bN\u0001N\u0001N\u0001N\u0003N\u0b48\b"+
		"N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0003N\u0b51\bN\u0001"+
		"N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001"+
		"N\u0001N\u0001N\u0001N\u0001N\u0001N\u0003N\u0b63\bN\u0001N\u0001N\u0003"+
		"N\u0b67\bN\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0003N\u0b6f\bN\u0001"+
		"N\u0001N\u0003N\u0b73\bN\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001"+
		"N\u0001N\u0001N\u0001N\u0003N\u0b7f\bN\u0001N\u0003N\u0b82\bN\u0001N\u0001"+
		"N\u0001N\u0001N\u0001N\u0001N\u0001N\u0003N\u0b8b\bN\u0001N\u0001N\u0001"+
		"N\u0001N\u0001N\u0001N\u0001N\u0001N\u0001N\u0003N\u0b96\bN\u0001N\u0003"+
		"N\u0b99\bN\u0001N\u0001N\u0001N\u0001N\u0005N\u0b9f\bN\nN\fN\u0ba2\tN"+
		"\u0001N\u0001N\u0001N\u0003N\u0ba7\bN\u0001O\u0001O\u0001O\u0003O\u0bac"+
		"\bO\u0001O\u0001O\u0001O\u0001O\u0005O\u0bb2\bO\nO\fO\u0bb5\tO\u0001O"+
		"\u0001O\u0001O\u0001O\u0001O\u0003O\u0bbc\bO\u0001O\u0001O\u0001O\u0001"+
		"O\u0001O\u0003O\u0bc3\bO\u0001O\u0001O\u0001O\u0001O\u0001O\u0003O\u0bca"+
		"\bO\u0001O\u0001O\u0001O\u0001O\u0001O\u0003O\u0bd1\bO\u0001O\u0001O\u0001"+
		"O\u0001O\u0001O\u0001O\u0001O\u0001O\u0001O\u0001O\u0001O\u0005O\u0bde"+
		"\bO\nO\fO\u0be1\tO\u0001O\u0001O\u0001O\u0001O\u0001O\u0001O\u0001O\u0001"+
		"O\u0001O\u0001O\u0003O\u0bed\bO\u0001O\u0001O\u0001O\u0001O\u0003O\u0bf3"+
		"\bO\u0001O\u0001O\u0001O\u0001O\u0003O\u0bf9\bO\u0001O\u0001O\u0001O\u0001"+
		"O\u0003O\u0bff\bO\u0001O\u0001O\u0001O\u0001O\u0003O\u0c05\bO\u0001O\u0001"+
		"O\u0001O\u0001O\u0003O\u0c0b\bO\u0001O\u0001O\u0001O\u0001O\u0003O\u0c11"+
		"\bO\u0001P\u0001P\u0001P\u0003P\u0c16\bP\u0001P\u0001P\u0001Q\u0001Q\u0001"+
		"Q\u0003Q\u0c1d\bQ\u0001Q\u0001Q\u0001R\u0001R\u0001R\u0003R\u0c24\bR\u0001"+
		"R\u0003R\u0c27\bR\u0001R\u0001R\u0001R\u0001R\u0001R\u0003R\u0c2e\bR\u0001"+
		"R\u0001R\u0001R\u0003R\u0c33\bR\u0001R\u0005R\u0c36\bR\nR\fR\u0c39\tR"+
		"\u0001R\u0003R\u0c3c\bR\u0001S\u0001S\u0001S\u0001S\u0001S\u0001S\u0001"+
		"S\u0001S\u0001T\u0001T\u0001T\u0003T\u0c49\bT\u0001T\u0001T\u0001U\u0001"+
		"U\u0001U\u0003U\u0c50\bU\u0001U\u0001U\u0001V\u0001V\u0001V\u0003V\u0c57"+
		"\bV\u0001V\u0001V\u0001W\u0001W\u0003W\u0c5d\bW\u0001W\u0001W\u0003W\u0c61"+
		"\bW\u0001W\u0001W\u0003W\u0c65\bW\u0001W\u0003W\u0c68\bW\u0001X\u0001"+
		"X\u0001X\u0001X\u0001X\u0003X\u0c6f\bX\u0001X\u0003X\u0c72\bX\u0001Y\u0001"+
		"Y\u0001Y\u0003Y\u0c77\bY\u0001Y\u0001Y\u0001Z\u0001Z\u0001Z\u0003Z\u0c7e"+
		"\bZ\u0001Z\u0001Z\u0001Z\u0005Z\u0c83\bZ\nZ\fZ\u0c86\tZ\u0001Z\u0003Z"+
		"\u0c89\bZ\u0001[\u0001[\u0001[\u0003[\u0c8e\b[\u0001[\u0001[\u0001[\u0005"+
		"[\u0c93\b[\n[\f[\u0c96\t[\u0001\\\u0001\\\u0001\\\u0001\\\u0001\\\u0001"+
		"\\\u0001\\\u0001\\\u0005\\\u0ca0\b\\\n\\\f\\\u0ca3\t\\\u0003\\\u0ca5\b"+
		"\\\u0001\\\u0001\\\u0001\\\u0003\\\u0caa\b\\\u0001\\\u0001\\\u0001\\\u0003"+
		"\\\u0caf\b\\\u0005\\\u0cb1\b\\\n\\\f\\\u0cb4\t\\\u0001\\\u0001\\\u0001"+
		"\\\u0003\\\u0cb9\b\\\u0001]\u0001]\u0003]\u0cbd\b]\u0001]\u0001]\u0003"+
		"]\u0cc1\b]\u0001]\u0003]\u0cc4\b]\u0001]\u0001]\u0001]\u0005]\u0cc9\b"+
		"]\n]\f]\u0ccc\t]\u0001^\u0001^\u0001^\u0003^\u0cd1\b^\u0001^\u0001^\u0001"+
		"^\u0005^\u0cd6\b^\n^\f^\u0cd9\t^\u0001_\u0001_\u0003_\u0cdd\b_\u0001_"+
		"\u0001_\u0001_\u0001`\u0001`\u0003`\u0ce4\b`\u0001`\u0001`\u0003`\u0ce8"+
		"\b`\u0001a\u0001a\u0001a\u0001a\u0001a\u0003a\u0cef\ba\u0001a\u0003a\u0cf2"+
		"\ba\u0001b\u0001b\u0003b\u0cf6\bb\u0001c\u0001c\u0001c\u0001d\u0001d\u0001"+
		"d\u0001d\u0003d\u0cff\bd\u0001e\u0001e\u0003e\u0d03\be\u0001e\u0003e\u0d06"+
		"\be\u0001e\u0003e\u0d09\be\u0001e\u0001e\u0001e\u0001e\u0003e\u0d0f\b"+
		"e\u0001e\u0003e\u0d12\be\u0001e\u0001e\u0001e\u0001e\u0003e\u0d18\be\u0001"+
		"e\u0001e\u0001e\u0001e\u0001e\u0005e\u0d1f\be\ne\fe\u0d22\te\u0003e\u0d24"+
		"\be\u0001e\u0001e\u0001e\u0001e\u0001e\u0001e\u0001e\u0005e\u0d2d\be\n"+
		"e\fe\u0d30\te\u0003e\u0d32\be\u0001f\u0001f\u0001f\u0003f\u0d37\bf\u0001"+
		"f\u0003f\u0d3a\bf\u0001f\u0001f\u0001f\u0003f\u0d3f\bf\u0001f\u0001f\u0001"+
		"f\u0001f\u0001f\u0001f\u0001f\u0001f\u0003f\u0d49\bf\u0001f\u0001f\u0001"+
		"f\u0003f\u0d4e\bf\u0001f\u0001f\u0004f\u0d52\bf\u000bf\ff\u0d53\u0003"+
		"f\u0d56\bf\u0001f\u0001f\u0004f\u0d5a\bf\u000bf\ff\u0d5b\u0003f\u0d5e"+
		"\bf\u0001f\u0001f\u0001f\u0001f\u0003f\u0d64\bf\u0001f\u0001f\u0001f\u0001"+
		"f\u0005f\u0d6a\bf\nf\ff\u0d6d\tf\u0001f\u0001f\u0003f\u0d71\bf\u0001f"+
		"\u0001f\u0001f\u0001f\u0005f\u0d77\bf\nf\ff\u0d7a\tf\u0003f\u0d7c\bf\u0001"+
		"g\u0001g\u0001g\u0003g\u0d81\bg\u0001g\u0003g\u0d84\bg\u0001g\u0001g\u0001"+
		"g\u0003g\u0d89\bg\u0001g\u0001g\u0001g\u0001g\u0001g\u0001g\u0003g\u0d91"+
		"\bg\u0001g\u0001g\u0001g\u0001g\u0001g\u0001g\u0003g\u0d99\bg\u0001g\u0001"+
		"g\u0001g\u0001g\u0003g\u0d9f\bg\u0001g\u0001g\u0001g\u0001g\u0005g\u0da5"+
		"\bg\ng\fg\u0da8\tg\u0001g\u0001g\u0003g\u0dac\bg\u0001g\u0001g\u0001g"+
		"\u0001g\u0005g\u0db2\bg\ng\fg\u0db5\tg\u0003g\u0db7\bg\u0001h\u0001h\u0003"+
		"h\u0dbb\bh\u0001h\u0003h\u0dbe\bh\u0001h\u0001h\u0001h\u0001h\u0001h\u0001"+
		"h\u0003h\u0dc6\bh\u0001h\u0001h\u0001h\u0001h\u0003h\u0dcc\bh\u0001h\u0001"+
		"h\u0001h\u0001h\u0001h\u0005h\u0dd3\bh\nh\fh\u0dd6\th\u0003h\u0dd8\bh"+
		"\u0001i\u0001i\u0003i\u0ddc\bi\u0001i\u0001i\u0003i\u0de0\bi\u0001i\u0001"+
		"i\u0004i\u0de4\bi\u000bi\fi\u0de5\u0001i\u0001i\u0003i\u0dea\bi\u0001"+
		"i\u0001i\u0003i\u0dee\bi\u0003i\u0df0\bi\u0001i\u0003i\u0df3\bi\u0001"+
		"i\u0003i\u0df6\bi\u0001i\u0003i\u0df9\bi\u0001i\u0001i\u0004i\u0dfd\b"+
		"i\u000bi\fi\u0dfe\u0001i\u0001i\u0003i\u0e03\bi\u0001i\u0003i\u0e06\b"+
		"i\u0001i\u0003i\u0e09\bi\u0001i\u0003i\u0e0c\bi\u0001i\u0003i\u0e0f\b"+
		"i\u0001i\u0001i\u0001i\u0004i\u0e14\bi\u000bi\fi\u0e15\u0003i\u0e18\b"+
		"i\u0001j\u0001j\u0003j\u0e1c\bj\u0001k\u0001k\u0001k\u0003k\u0e21\bk\u0001"+
		"k\u0001k\u0001k\u0001k\u0003k\u0e27\bk\u0001k\u0005k\u0e2a\bk\nk\fk\u0e2d"+
		"\tk\u0001l\u0001l\u0001l\u0001l\u0003l\u0e33\bl\u0001l\u0001l\u0001l\u0001"+
		"l\u0003l\u0e39\bl\u0001l\u0005l\u0e3c\bl\nl\fl\u0e3f\tl\u0003l\u0e41\b"+
		"l\u0001m\u0001m\u0001m\u0001m\u0003m\u0e47\bm\u0001n\u0001n\u0003n\u0e4b"+
		"\bn\u0001o\u0001o\u0001o\u0001o\u0001o\u0001o\u0003o\u0e53\bo\u0001o\u0003"+
		"o\u0e56\bo\u0001p\u0001p\u0003p\u0e5a\bp\u0001p\u0003p\u0e5d\bp\u0001"+
		"p\u0003p\u0e60\bp\u0001p\u0001p\u0001p\u0001p\u0001p\u0001p\u0001p\u0003"+
		"p\u0e69\bp\u0001p\u0001p\u0003p\u0e6d\bp\u0001p\u0003p\u0e70\bp\u0001"+
		"p\u0001p\u0003p\u0e74\bp\u0001q\u0001q\u0003q\u0e78\bq\u0001q\u0003q\u0e7b"+
		"\bq\u0001q\u0003q\u0e7e\bq\u0001q\u0001q\u0001q\u0003q\u0e83\bq\u0001"+
		"q\u0001q\u0001q\u0001q\u0003q\u0e89\bq\u0005q\u0e8b\bq\nq\fq\u0e8e\tq"+
		"\u0001q\u0001q\u0001q\u0001q\u0001q\u0001q\u0001q\u0003q\u0e97\bq\u0001"+
		"q\u0001q\u0001q\u0001q\u0003q\u0e9d\bq\u0005q\u0e9f\bq\nq\fq\u0ea2\tq"+
		"\u0001q\u0001q\u0001q\u0003q\u0ea7\bq\u0001q\u0001q\u0003q\u0eab\bq\u0001"+
		"r\u0001r\u0001r\u0001r\u0003r\u0eb1\br\u0001r\u0003r\u0eb4\br\u0001s\u0001"+
		"s\u0001s\u0001s\u0001s\u0001s\u0001s\u0001s\u0001s\u0001s\u0003s\u0ec0"+
		"\bs\u0001s\u0001s\u0003s\u0ec4\bs\u0001s\u0001s\u0003s\u0ec8\bs\u0001"+
		"t\u0001t\u0001t\u0001t\u0001t\u0001t\u0003t\u0ed0\bt\u0001t\u0001t\u0003"+
		"t\u0ed4\bt\u0001u\u0001u\u0001u\u0001u\u0001v\u0001v\u0003v\u0edc\bv\u0001"+
		"v\u0003v\u0edf\bv\u0001v\u0001v\u0003v\u0ee3\bv\u0001v\u0003v\u0ee6\b"+
		"v\u0001v\u0001v\u0001v\u0001v\u0005v\u0eec\bv\nv\fv\u0eef\tv\u0001v\u0001"+
		"v\u0003v\u0ef3\bv\u0001v\u0003v\u0ef6\bv\u0001v\u0003v\u0ef9\bv\u0001"+
		"w\u0001w\u0003w\u0efd\bw\u0001w\u0003w\u0f00\bw\u0001w\u0001w\u0001w\u0001"+
		"w\u0001w\u0005w\u0f07\bw\nw\fw\u0f0a\tw\u0001w\u0001w\u0003w\u0f0e\bw"+
		"\u0001x\u0001x\u0001x\u0001x\u0001x\u0005x\u0f15\bx\nx\fx\u0f18\tx\u0001"+
		"y\u0001y\u0003y\u0f1c\by\u0001z\u0001z\u0001z\u0005z\u0f21\bz\nz\fz\u0f24"+
		"\tz\u0001{\u0001{\u0005{\u0f28\b{\n{\f{\u0f2b\t{\u0001{\u0001{\u0001{"+
		"\u0005{\u0f30\b{\n{\f{\u0f33\t{\u0001{\u0001{\u0001{\u0003{\u0f38\b{\u0001"+
		"|\u0001|\u0001|\u0001|\u0001|\u0001|\u0003|\u0f40\b|\u0001|\u0003|\u0f43"+
		"\b|\u0001|\u0003|\u0f46\b|\u0001|\u0001|\u0001|\u0005|\u0f4b\b|\n|\f|"+
		"\u0f4e\t|\u0003|\u0f50\b|\u0001|\u0001|\u0001|\u0001|\u0001|\u0003|\u0f57"+
		"\b|\u0001|\u0003|\u0f5a\b|\u0001|\u0001|\u0001|\u0001|\u0001|\u0001|\u0003"+
		"|\u0f62\b|\u0001}\u0001}\u0001}\u0001}\u0003}\u0f68\b}\u0001}\u0001}\u0001"+
		"}\u0001}\u0001~\u0001~\u0001~\u0001~\u0001~\u0003~\u0f73\b~\u0001\u007f"+
		"\u0003\u007f\u0f76\b\u007f\u0001\u007f\u0001\u007f\u0003\u007f\u0f7a\b"+
		"\u007f\u0001\u007f\u0001\u007f\u0001\u007f\u0001\u007f\u0001\u007f\u0001"+
		"\u007f\u0001\u007f\u0001\u007f\u0003\u007f\u0f84\b\u007f\u0001\u007f\u0001"+
		"\u007f\u0001\u007f\u0001\u007f\u0003\u007f\u0f8a\b\u007f\u0001\u007f\u0001"+
		"\u007f\u0003\u007f\u0f8e\b\u007f\u0001\u007f\u0001\u007f\u0003\u007f\u0f92"+
		"\b\u007f\u0001\u007f\u0001\u007f\u0001\u007f\u0001\u007f\u0001\u007f\u0001"+
		"\u007f\u0001\u007f\u0001\u007f\u0003\u007f\u0f9c\b\u007f\u0001\u007f\u0001"+
		"\u007f\u0001\u007f\u0003\u007f\u0fa1\b\u007f\u0003\u007f\u0fa3\b\u007f"+
		"\u0001\u007f\u0001\u007f\u0003\u007f\u0fa7\b\u007f\u0001\u0080\u0001\u0080"+
		"\u0001\u0080\u0001\u0080\u0001\u0080\u0001\u0080\u0001\u0080\u0001\u0080"+
		"\u0003\u0080\u0fb1\b\u0080\u0001\u0081\u0001\u0081\u0001\u0081\u0001\u0081"+
		"\u0001\u0081\u0001\u0081\u0001\u0081\u0001\u0081\u0003\u0081\u0fbb\b\u0081"+
		"\u0001\u0082\u0001\u0082\u0005\u0082\u0fbf\b\u0082\n\u0082\f\u0082\u0fc2"+
		"\t\u0082\u0001\u0082\u0001\u0082\u0003\u0082\u0fc6\b\u0082\u0001\u0082"+
		"\u0003\u0082\u0fc9\b\u0082\u0001\u0082\u0003\u0082\u0fcc\b\u0082\u0001"+
		"\u0082\u0003\u0082\u0fcf\b\u0082\u0001\u0082\u0003\u0082\u0fd2\b\u0082"+
		"\u0001\u0082\u0003\u0082\u0fd5\b\u0082\u0001\u0082\u0003\u0082\u0fd8\b"+
		"\u0082\u0001\u0082\u0001\u0082\u0005\u0082\u0fdc\b\u0082\n\u0082\f\u0082"+
		"\u0fdf\t\u0082\u0001\u0082\u0001\u0082\u0003\u0082\u0fe3\b\u0082\u0001"+
		"\u0082\u0003\u0082\u0fe6\b\u0082\u0001\u0082\u0003\u0082\u0fe9\b\u0082"+
		"\u0001\u0082\u0003\u0082\u0fec\b\u0082\u0001\u0082\u0003\u0082\u0fef\b"+
		"\u0082\u0001\u0082\u0003\u0082\u0ff2\b\u0082\u0001\u0082\u0003\u0082\u0ff5"+
		"\b\u0082\u0003\u0082\u0ff7\b\u0082\u0001\u0083\u0001\u0083\u0005\u0083"+
		"\u0ffb\b\u0083\n\u0083\f\u0083\u0ffe\t\u0083\u0001\u0083\u0001\u0083\u0003"+
		"\u0083\u1002\b\u0083\u0001\u0083\u0003\u0083\u1005\b\u0083\u0001\u0083"+
		"\u0003\u0083\u1008\b\u0083\u0001\u0083\u0003\u0083\u100b\b\u0083\u0001"+
		"\u0083\u0003\u0083\u100e\b\u0083\u0001\u0083\u0003\u0083\u1011\b\u0083"+
		"\u0001\u0084\u0001\u0084\u0003\u0084\u1015\b\u0084\u0001\u0084\u0001\u0084"+
		"\u0001\u0085\u0001\u0085\u0003\u0085\u101b\b\u0085\u0001\u0085\u0001\u0085"+
		"\u0003\u0085\u101f\b\u0085\u0001\u0086\u0001\u0086\u0001\u0086\u0001\u0086"+
		"\u0001\u0086\u0001\u0086\u0003\u0086\u1027\b\u0086\u0001\u0086\u0001\u0086"+
		"\u0003\u0086\u102b\b\u0086\u0001\u0086\u0003\u0086\u102e\b\u0086\u0003"+
		"\u0086\u1030\b\u0086\u0001\u0087\u0001\u0087\u0001\u0087\u0001\u0087\u0001"+
		"\u0087\u0001\u0087\u0001\u0087\u0001\u0087\u0001\u0087\u0001\u0087\u0001"+
		"\u0087\u0003\u0087\u103d\b\u0087\u0001\u0087\u0003\u0087\u1040\b\u0087"+
		"\u0001\u0088\u0001\u0088\u0001\u0088\u0005\u0088\u1045\b\u0088\n\u0088"+
		"\f\u0088\u1048\t\u0088\u0001\u0089\u0001\u0089\u0001\u0089\u0001\u0089"+
		"\u0001\u0089\u0001\u0089\u0001\u0089\u0003\u0089\u1051\b\u0089\u0001\u0089"+
		"\u0003\u0089\u1054\b\u0089\u0001\u0089\u0001\u0089\u0001\u0089\u0003\u0089"+
		"\u1059\b\u0089\u0003\u0089\u105b\b\u0089\u0001\u0089\u0001\u0089\u0003"+
		"\u0089\u105f\b\u0089\u0001\u0089\u0001\u0089\u0001\u0089\u0001\u0089\u0001"+
		"\u0089\u0001\u0089\u0003\u0089\u1067\b\u0089\u0001\u008a\u0001\u008a\u0001"+
		"\u008a\u0001\u008a\u0003\u008a\u106d\b\u008a\u0001\u008a\u0001\u008a\u0001"+
		"\u008a\u0001\u008b\u0001\u008b\u0001\u008b\u0001\u008b\u0003\u008b\u1076"+
		"\b\u008b\u0001\u008b\u0001\u008b\u0001\u008b\u0001\u008c\u0001\u008c\u0001"+
		"\u008c\u0001\u008c\u0001\u008c\u0001\u008c\u0001\u008c\u0001\u008c\u0003"+
		"\u008c\u1083\b\u008c\u0001\u008d\u0001\u008d\u0003\u008d\u1087\b\u008d"+
		"\u0001\u008d\u0001\u008d\u0005\u008d\u108b\b\u008d\n\u008d\f\u008d\u108e"+
		"\t\u008d\u0001\u008e\u0001\u008e\u0001\u008e\u0001\u008e\u0001\u008e\u0001"+
		"\u008e\u0003\u008e\u1096\b\u008e\u0001\u008e\u0003\u008e\u1099\b\u008e"+
		"\u0001\u008e\u0001\u008e\u0003\u008e\u109d\b\u008e\u0001\u008e\u0003\u008e"+
		"\u10a0\b\u008e\u0001\u008e\u0001\u008e\u0003\u008e\u10a4\b\u008e\u0001"+
		"\u008e\u0001\u008e\u0003\u008e\u10a8\b\u008e\u0001\u008e\u0003\u008e\u10ab"+
		"\b\u008e\u0003\u008e\u10ad\b\u008e\u0001\u008f\u0001\u008f\u0001\u008f"+
		"\u0001\u008f\u0005\u008f\u10b3\b\u008f\n\u008f\f\u008f\u10b6\t\u008f\u0001"+
		"\u008f\u0001\u008f\u0001\u008f\u0001\u008f\u0001\u008f\u0001\u008f\u0001"+
		"\u008f\u0001\u008f\u0001\u008f\u0003\u008f\u10c1\b\u008f\u0001\u008f\u0001"+
		"\u008f\u0004\u008f\u10c5\b\u008f\u000b\u008f\f\u008f\u10c6\u0003\u008f"+
		"\u10c9\b\u008f\u0001\u008f\u0001\u008f\u0004\u008f\u10cd\b\u008f\u000b"+
		"\u008f\f\u008f\u10ce\u0003\u008f\u10d1\b\u008f\u0003\u008f\u10d3\b\u008f"+
		"\u0001\u0090\u0001\u0090\u0001\u0090\u0001\u0090\u0003\u0090\u10d9\b\u0090"+
		"\u0001\u0090\u0001\u0090\u0001\u0090\u0001\u0090\u0001\u0090\u0001\u0090"+
		"\u0003\u0090\u10e1\b\u0090\u0001\u0091\u0001\u0091\u0001\u0091\u0001\u0091"+
		"\u0001\u0091\u0001\u0091\u0003\u0091\u10e9\b\u0091\u0001\u0092\u0001\u0092"+
		"\u0003\u0092\u10ed\b\u0092\u0001\u0092\u0001\u0092\u0003\u0092\u10f1\b"+
		"\u0092\u0001\u0093\u0001\u0093\u0001\u0093\u0001\u0093\u0001\u0093\u0005"+
		"\u0093\u10f8\b\u0093\n\u0093\f\u0093\u10fb\t\u0093\u0001\u0093\u0001\u0093"+
		"\u0003\u0093\u10ff\b\u0093\u0001\u0094\u0001\u0094\u0001\u0094\u0001\u0095"+
		"\u0001\u0095\u0001\u0095\u0001\u0095\u0001\u0095\u0001\u0095\u0001\u0095"+
		"\u0001\u0095\u0001\u0095\u0001\u0095\u0001\u0095\u0001\u0095\u0001\u0095"+
		"\u0005\u0095\u1111\b\u0095\n\u0095\f\u0095\u1114\t\u0095\u0001\u0096\u0001"+
		"\u0096\u0003\u0096\u1118\b\u0096\u0001\u0097\u0001\u0097\u0001\u0097\u0001"+
		"\u0097\u0003\u0097\u111e\b\u0097\u0001\u0097\u0001\u0097\u0001\u0097\u0001"+
		"\u0097\u0001\u0097\u0003\u0097\u1125\b\u0097\u0001\u0098\u0001\u0098\u0001"+
		"\u0098\u0003\u0098\u112a\b\u0098\u0001\u0099\u0001\u0099\u0001\u0099\u0001"+
		"\u0099\u0001\u0099\u0005\u0099\u1131\b\u0099\n\u0099\f\u0099\u1134\t\u0099"+
		"\u0003\u0099\u1136\b\u0099\u0001\u009a\u0001\u009a\u0003\u009a\u113a\b"+
		"\u009a\u0001\u009b\u0001\u009b\u0003\u009b\u113e\b\u009b\u0001\u009b\u0001"+
		"\u009b\u0003\u009b\u1142\b\u009b\u0001\u009b\u0003\u009b\u1145\b\u009b"+
		"\u0001\u009b\u0003\u009b\u1148\b\u009b\u0001\u009b\u0003\u009b\u114b\b"+
		"\u009b\u0001\u009c\u0001\u009c\u0003\u009c\u114f\b\u009c\u0001\u009c\u0001"+
		"\u009c\u0003\u009c\u1153\b\u009c\u0001\u009c\u0003\u009c\u1156\b\u009c"+
		"\u0001\u009c\u0003\u009c\u1159\b\u009c\u0001\u009c\u0003\u009c\u115c\b"+
		"\u009c\u0001\u009d\u0001\u009d\u0001\u009d\u0001\u009e\u0001\u009e\u0003"+
		"\u009e\u1163\b\u009e\u0001\u009e\u0001\u009e\u0003\u009e\u1167\b\u009e"+
		"\u0001\u009e\u0001\u009e\u0001\u009f\u0001\u009f\u0001\u009f\u0001\u009f"+
		"\u0001\u00a0\u0001\u00a0\u0001\u00a0\u0001\u00a0\u0001\u00a0\u0005\u00a0"+
		"\u1174\b\u00a0\n\u00a0\f\u00a0\u1177\t\u00a0\u0001\u00a0\u0003\u00a0\u117a"+
		"\b\u00a0\u0001\u00a1\u0001\u00a1\u0001\u00a1\u0001\u00a2\u0001\u00a2\u0001"+
		"\u00a2\u0001\u00a2\u0001\u00a2\u0001\u00a3\u0001\u00a3\u0003\u00a3\u1186"+
		"\b\u00a3\u0001\u00a3\u0001\u00a3\u0001\u00a3\u0001\u00a3\u0005\u00a3\u118c"+
		"\b\u00a3\n\u00a3\f\u00a3\u118f\t\u00a3\u0001\u00a4\u0001\u00a4\u0001\u00a4"+
		"\u0001\u00a4\u0001\u00a4\u0001\u00a4\u0001\u00a4\u0003\u00a4\u1198\b\u00a4"+
		"\u0001\u00a5\u0001\u00a5\u0003\u00a5\u119c\b\u00a5\u0001\u00a5\u0003\u00a5"+
		"\u119f\b\u00a5\u0001\u00a5\u0001\u00a5\u0001\u00a6\u0001\u00a6\u0003\u00a6"+
		"\u11a5\b\u00a6\u0001\u00a6\u0003\u00a6\u11a8\b\u00a6\u0001\u00a6\u0003"+
		"\u00a6\u11ab\b\u00a6\u0001\u00a7\u0001\u00a7\u0001\u00a7\u0001\u00a7\u0001"+
		"\u00a7\u0001\u00a7\u0001\u00a7\u0003\u00a7\u11b4\b\u00a7\u0001\u00a8\u0001"+
		"\u00a8\u0001\u00a8\u0001\u00a8\u0001\u00a8\u0001\u00a8\u0001\u00a8\u0003"+
		"\u00a8\u11bd\b\u00a8\u0001\u00a9\u0001\u00a9\u0001\u00a9\u0001\u00a9\u0001"+
		"\u00a9\u0001\u00a9\u0005\u00a9\u11c5\b\u00a9\n\u00a9\f\u00a9\u11c8\t\u00a9"+
		"\u0001\u00a9\u0003\u00a9\u11cb\b\u00a9\u0001\u00aa\u0001\u00aa\u0001\u00aa"+
		"\u0001\u00aa\u0001\u00aa\u0001\u00aa\u0005\u00aa\u11d3\b\u00aa\n\u00aa"+
		"\f\u00aa\u11d6\t\u00aa\u0001\u00ab\u0001\u00ab\u0001\u00ab\u0001\u00ab"+
		"\u0001\u00ab\u0001\u00ab\u0001\u00ab\u0003\u00ab\u11df\b\u00ab\u0001\u00ac"+
		"\u0001\u00ac\u0001\u00ac\u0001\u00ad\u0001\u00ad\u0001\u00ad\u0003\u00ad"+
		"\u11e7\b\u00ad\u0001\u00ad\u0003\u00ad\u11ea\b\u00ad\u0001\u00ae\u0001"+
		"\u00ae\u0001\u00ae\u0001\u00ae\u0001\u00ae\u0005\u00ae\u11f1\b\u00ae\n"+
		"\u00ae\f\u00ae\u11f4\t\u00ae\u0003\u00ae\u11f6\b\u00ae\u0001\u00ae\u0001"+
		"\u00ae\u0003\u00ae\u11fa\b\u00ae\u0001\u00ae\u0005\u00ae\u11fd\b\u00ae"+
		"\n\u00ae\f\u00ae\u1200\t\u00ae\u0001\u00ae\u0003\u00ae\u1203\b\u00ae\u0001"+
		"\u00af\u0001\u00af\u0001\u00af\u0001\u00af\u0001\u00af\u0005\u00af\u120a"+
		"\b\u00af\n\u00af\f\u00af\u120d\t\u00af\u0003\u00af\u120f\b\u00af\u0001"+
		"\u00b0\u0001\u00b0\u0001\u00b0\u0001\u00b1\u0001\u00b1\u0001\u00b1\u0001"+
		"\u00b2\u0001\u00b2\u0001\u00b2\u0001\u00b2\u0001\u00b2\u0001\u00b2\u0001"+
		"\u00b2\u0001\u00b2\u0001\u00b2\u0001\u00b2\u0001\u00b2\u0001\u00b2\u0001"+
		"\u00b2\u0001\u00b2\u0001\u00b2\u0001\u00b2\u0001\u00b2\u0001\u00b2\u0001"+
		"\u00b2\u0001\u00b2\u0001\u00b2\u0005\u00b2\u122c\b\u00b2\n\u00b2\f\u00b2"+
		"\u122f\t\u00b2\u0003\u00b2\u1231\b\u00b2\u0001\u00b2\u0003\u00b2\u1234"+
		"\b\u00b2\u0001\u00b3\u0001\u00b3\u0001\u00b4\u0001\u00b4\u0001\u00b5\u0001"+
		"\u00b5\u0001\u00b6\u0001\u00b6\u0001\u00b6\u0001\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\u0001\u00b7\u0001"+
		"\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001"+
		"\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001"+
		"\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001"+
		"\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001"+
		"\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0005\u00b7\u126a"+
		"\b\u00b7\n\u00b7\f\u00b7\u126d\t\u00b7\u0001\u00b7\u0001\u00b7\u0003\u00b7"+
		"\u1271\b\u00b7\u0001\u00b8\u0001\u00b8\u0001\u00b8\u0001\u00b8\u0001\u00b8"+
		"\u0001\u00b8\u0001\u00b9\u0001\u00b9\u0001\u00ba\u0001\u00ba\u0001\u00ba"+
		"\u0001\u00ba\u0001\u00ba\u0001\u00ba\u0001\u00ba\u0001\u00ba\u0001\u00ba"+
		"\u0001\u00ba\u0001\u00ba\u0001\u00ba\u0001\u00ba\u0001\u00ba\u0001\u00ba"+
		"\u0001\u00ba\u0001\u00ba\u0001\u00ba\u0003\u00ba\u128d\b\u00ba\u0001\u00bb"+
		"\u0001\u00bb\u0001\u00bb\u0001\u00bb\u0001\u00bb\u0001\u00bb\u0001\u00bb"+
		"\u0001\u00bb\u0001\u00bb\u0001\u00bb\u0001\u00bb\u0001\u00bb\u0003\u00bb"+
		"\u129b\b\u00bb\u0001\u00bc\u0001\u00bc\u0001\u00bc\u0005\u00bc\u12a0\b"+
		"\u00bc\n\u00bc\f\u00bc\u12a3\t\u00bc\u0001\u00bc\u0003\u00bc\u12a6\b\u00bc"+
		"\u0001\u00bd\u0001\u00bd\u0001\u00bd\u0001\u00bd\u0003\u00bd\u12ac\b\u00bd"+
		"\u0001\u00be\u0001\u00be\u0001\u00be\u0001\u00be\u0001\u00be\u0001\u00be"+
		"\u0003\u00be\u12b4\b\u00be\u0003\u00be\u12b6\b\u00be\u0001\u00bf\u0001"+
		"\u00bf\u0001\u00bf\u0001\u00bf\u0001\u00c0\u0001\u00c0\u0001\u00c0\u0001"+
		"\u00c0\u0001\u00c0\u0003\u00c0\u12c1\b\u00c0\u0001\u00c1\u0001\u00c1\u0001"+
		"\u00c1\u0001\u00c1\u0001\u00c2\u0001\u00c2\u0001\u00c2\u0001\u00c2\u0003"+
		"\u00c2\u12cb\b\u00c2\u0001\u00c3\u0001\u00c3\u0001\u00c3\u0001\u00c3\u0001"+
		"\u00c3\u0003\u00c3\u12d2\b\u00c3\u0001\u00c4\u0001\u00c4\u0001\u00c4\u0001"+
		"\u00c4\u0003\u00c4\u12d8\b\u00c4\u0001\u00c5\u0001\u00c5\u0001\u00c5\u0001"+
		"\u00c5\u0001\u00c6\u0001\u00c6\u0003\u00c6\u12e0\b\u00c6\u0001\u00c7\u0001"+
		"\u00c7\u0001\u00c7\u0003\u00c7\u12e5\b\u00c7\u0001\u00c7\u0001\u00c7\u0001"+
		"\u00c7\u0001\u00c7\u0005\u00c7\u12eb\b\u00c7\n\u00c7\f\u00c7\u12ee\t\u00c7"+
		"\u0001\u00c7\u0001\u00c7\u0001\u00c7\u0005\u00c7\u12f3\b\u00c7\n\u00c7"+
		"\f\u00c7\u12f6\t\u00c7\u0001\u00c7\u0001\u00c7\u0001\u00c7\u0005\u00c7"+
		"\u12fb\b\u00c7\n\u00c7\f\u00c7\u12fe\t\u00c7\u0001\u00c7\u0001\u00c7\u0001"+
		"\u00c7\u0005\u00c7\u1303\b\u00c7\n\u00c7\f\u00c7\u1306\t\u00c7\u0001\u00c7"+
		"\u0005\u00c7\u1309\b\u00c7\n\u00c7\f\u00c7\u130c\t\u00c7\u0003\u00c7\u130e"+
		"\b\u00c7\u0001\u00c7\u0001\u00c7\u0003\u00c7\u1312\b\u00c7\u0001\u00c8"+
		"\u0001\u00c8\u0001\u00c8\u0003\u00c8\u1317\b\u00c8\u0001\u00c8\u0004\u00c8"+
		"\u131a\b\u00c8\u000b\u00c8\f\u00c8\u131b\u0001\u00c8\u0001\u00c8\u0004"+
		"\u00c8\u1320\b\u00c8\u000b\u00c8\f\u00c8\u1321\u0003\u00c8\u1324\b\u00c8"+
		"\u0001\u00c8\u0001\u00c8\u0001\u00c8\u0001\u00c9\u0001\u00c9\u0001\u00c9"+
		"\u0001\u00c9\u0004\u00c9\u132d\b\u00c9\u000b\u00c9\f\u00c9\u132e\u0001"+
		"\u00c9\u0005\u00c9\u1332\b\u00c9\n\u00c9\f\u00c9\u1335\t\u00c9\u0001\u00c9"+
		"\u0001\u00c9\u0004\u00c9\u1339\b\u00c9\u000b\u00c9\f\u00c9\u133a\u0003"+
		"\u00c9\u133d\b\u00c9\u0001\u00c9\u0001\u00c9\u0001\u00c9\u0001\u00ca\u0001"+
		"\u00ca\u0001\u00ca\u0001\u00cb\u0001\u00cb\u0001\u00cb\u0001\u00cc\u0001"+
		"\u00cc\u0001\u00cc\u0003\u00cc\u134b\b\u00cc\u0001\u00cc\u0001\u00cc\u0004"+
		"\u00cc\u134f\b\u00cc\u000b\u00cc\f\u00cc\u1350\u0001\u00cc\u0001\u00cc"+
		"\u0001\u00cc\u0003\u00cc\u1356\b\u00cc\u0001\u00cd\u0001\u00cd\u0001\u00cd"+
		"\u0003\u00cd\u135b\b\u00cd\u0001\u00cd\u0001\u00cd\u0004\u00cd\u135f\b"+
		"\u00cd\u000b\u00cd\f\u00cd\u1360\u0001\u00cd\u0001\u00cd\u0001\u00cd\u0001"+
		"\u00cd\u0001\u00cd\u0003\u00cd\u1368\b\u00cd\u0001\u00ce\u0001\u00ce\u0001"+
		"\u00ce\u0001\u00cf\u0001\u00cf\u0001\u00cf\u0003\u00cf\u1370\b\u00cf\u0001"+
		"\u00cf\u0001\u00cf\u0001\u00cf\u0001\u00cf\u0004\u00cf\u1376\b\u00cf\u000b"+
		"\u00cf\f\u00cf\u1377\u0001\u00cf\u0001\u00cf\u0001\u00cf\u0003\u00cf\u137d"+
		"\b\u00cf\u0001\u00d0\u0001\u00d0\u0001\u00d0\u0001\u00d0\u0003\u00d0\u1383"+
		"\b\u00d0\u0001\u00d0\u0003\u00d0\u1386\b\u00d0\u0001\u00d0\u0001\u00d0"+
		"\u0001\u00d0\u0001\u00d0\u0001\u00d0\u0001\u00d0\u0003\u00d0\u138e\b\u00d0"+
		"\u0001\u00d1\u0001\u00d1\u0001\u00d1\u0001\u00d1\u0001\u00d1\u0003\u00d1"+
		"\u1395\b\u00d1\u0001\u00d2\u0001\u00d2\u0001\u00d2\u0001\u00d2\u0001\u00d2"+
		"\u0001\u00d2\u0001\u00d2\u0003\u00d2\u139e\b\u00d2\u0001\u00d2\u0003\u00d2"+
		"\u13a1\b\u00d2\u0001\u00d3\u0001\u00d3\u0001\u00d3\u0001\u00d3\u0001\u00d3"+
		"\u0001\u00d3\u0001\u00d4\u0001\u00d4\u0001\u00d4\u0001\u00d4\u0001\u00d4"+
		"\u0001\u00d4\u0001\u00d4\u0005\u00d4\u13b0\b\u00d4\n\u00d4\f\u00d4\u13b3"+
		"\t\u00d4\u0001\u00d4\u0001\u00d4\u0001\u00d5\u0001\u00d5\u0001\u00d5\u0003"+
		"\u00d5\u13ba\b\u00d5\u0001\u00d5\u0001\u00d5\u0001\u00d5\u0001\u00d5\u0001"+
		"\u00d5\u0001\u00d5\u0003\u00d5\u13c2\b\u00d5\u0001\u00d6\u0001\u00d6\u0003"+
		"\u00d6\u13c6\b\u00d6\u0001\u00d6\u0001\u00d6\u0001\u00d7\u0001\u00d7\u0001"+
		"\u00d7\u0003\u00d7\u13cd\b\u00d7\u0001\u00d7\u0001\u00d7\u0004\u00d7\u13d1"+
		"\b\u00d7\u000b\u00d7\f\u00d7\u13d2\u0001\u00d8\u0001\u00d8\u0001\u00d8"+
		"\u0001\u00d8\u0004\u00d8\u13d9\b\u00d8\u000b\u00d8\f\u00d8\u13da\u0001"+
		"\u00d9\u0001\u00d9\u0001\u00d9\u0001\u00d9\u0001\u00d9\u0005\u00d9\u13e2"+
		"\b\u00d9\n\u00d9\f\u00d9\u13e5\t\u00d9\u0001\u00d9\u0001\u00d9\u0001\u00d9"+
		"\u0003\u00d9\u13ea\b\u00d9\u0001\u00d9\u0001\u00d9\u0001\u00d9\u0005\u00d9"+
		"\u13ef\b\u00d9\n\u00d9\f\u00d9\u13f2\t\u00d9\u0001\u00d9\u0001\u00d9\u0001"+
		"\u00d9\u0001\u00d9\u0003\u00d9\u13f8\b\u00d9\u0001\u00d9\u0005\u00d9\u13fb"+
		"\b\u00d9\n\u00d9\f\u00d9\u13fe\t\u00d9\u0003\u00d9\u1400\b\u00d9\u0003"+
		"\u00d9\u1402\b\u00d9\u0001\u00d9\u0001\u00d9\u0004\u00d9\u1406\b\u00d9"+
		"\u000b\u00d9\f\u00d9\u1407\u0003\u00d9\u140a\b\u00d9\u0001\u00d9\u0001"+
		"\u00d9\u0005\u00d9\u140e\b\u00d9\n\u00d9\f\u00d9\u1411\t\u00d9\u0001\u00d9"+
		"\u0001\u00d9\u0001\u00d9\u0001\u00d9\u0003\u00d9\u1417\b\u00d9\u0003\u00d9"+
		"\u1419\b\u00d9\u0001\u00da\u0001\u00da\u0001\u00da\u0001\u00da\u0001\u00da"+
		"\u0005\u00da\u1420\b\u00da\n\u00da\f\u00da\u1423\t\u00da\u0001\u00da\u0001"+
		"\u00da\u0001\u00da\u0003\u00da\u1428\b\u00da\u0001\u00da\u0001\u00da\u0001"+
		"\u00da\u0005\u00da\u142d\b\u00da\n\u00da\f\u00da\u1430\t\u00da\u0001\u00da"+
		"\u0001\u00da\u0001\u00da\u0001\u00da\u0003\u00da\u1436\b\u00da\u0001\u00da"+
		"\u0005\u00da\u1439\b\u00da\n\u00da\f\u00da\u143c\t\u00da\u0003\u00da\u143e"+
		"\b\u00da\u0003\u00da\u1440\b\u00da\u0001\u00da\u0001\u00da\u0004\u00da"+
		"\u1444\b\u00da\u000b\u00da\f\u00da\u1445\u0003\u00da\u1448\b\u00da\u0001"+
		"\u00da\u0001\u00da\u0005\u00da\u144c\b\u00da\n\u00da\f\u00da\u144f\t\u00da"+
		"\u0001\u00da\u0001\u00da\u0001\u00da\u0001\u00da\u0003\u00da\u1455\b\u00da"+
		"\u0003\u00da\u1457\b\u00da\u0001\u00db\u0001\u00db\u0001\u00db\u0003\u00db"+
		"\u145c\b\u00db\u0001\u00db\u0001\u00db\u0001\u00db\u0005\u00db\u1461\b"+
		"\u00db\n\u00db\f\u00db\u1464\t\u00db\u0001\u00dc\u0001\u00dc\u0001\u00dc"+
		"\u0001\u00dc\u0005\u00dc\u146a\b\u00dc\n\u00dc\f\u00dc\u146d\t\u00dc\u0001"+
		"\u00dc\u0001\u00dc\u0003\u00dc\u1471\b\u00dc\u0001\u00dc\u0001\u00dc\u0001"+
		"\u00dc\u0001\u00dc\u0001\u00dc\u0005\u00dc\u1478\b\u00dc\n\u00dc\f\u00dc"+
		"\u147b\t\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0003\u00dc"+
		"\u1481\b\u00dc\u0001\u00dc\u0005\u00dc\u1484\b\u00dc\n\u00dc\f\u00dc\u1487"+
		"\t\u00dc\u0003\u00dc\u1489\b\u00dc\u0003\u00dc\u148b\b\u00dc\u0001\u00dc"+
		"\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0005\u00dc\u1491\b\u00dc\n\u00dc"+
		"\f\u00dc\u1494\t\u00dc\u0003\u00dc\u1496\b\u00dc\u0001\u00dc\u0001\u00dc"+
		"\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0003\u00dc\u149e\b\u00dc"+
		"\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0003\u00dc\u14a3\b\u00dc\u0001\u00dc"+
		"\u0001\u00dc\u0001\u00dc\u0003\u00dc\u14a8\b\u00dc\u0005\u00dc\u14aa\b"+
		"\u00dc\n\u00dc\f\u00dc\u14ad\t\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc"+
		"\u0003\u00dc\u14b2\b\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0003\u00dc"+
		"\u14b7\b\u00dc\u0005\u00dc\u14b9\b\u00dc\n\u00dc\f\u00dc\u14bc\t\u00dc"+
		"\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0003\u00dc\u14c1\b\u00dc\u0003\u00dc"+
		"\u14c3\b\u00dc\u0001\u00dd\u0001\u00dd\u0001\u00dd\u0001\u00dd\u0001\u00dd"+
		"\u0001\u00dd\u0001\u00dd\u0005\u00dd\u14cc\b\u00dd\n\u00dd\f\u00dd\u14cf"+
		"\t\u00dd\u0003\u00dd\u14d1\b\u00dd\u0001\u00dd\u0001\u00dd\u0001\u00dd"+
		"\u0005\u00dd\u14d6\b\u00dd\n\u00dd\f\u00dd\u14d9\t\u00dd\u0003\u00dd\u14db"+
		"\b\u00dd\u0001\u00de\u0001\u00de\u0001\u00de\u0001\u00de\u0001\u00de\u0001"+
		"\u00de\u0001\u00de\u0001\u00de\u0005\u00de\u14e5\b\u00de\n\u00de\f\u00de"+
		"\u14e8\t\u00de\u0001\u00de\u0001\u00de\u0001\u00de\u0003\u00de\u14ed\b"+
		"\u00de\u0001\u00df\u0001\u00df\u0001\u00df\u0001\u00df\u0001\u00df\u0005"+
		"\u00df\u14f4\b\u00df\n\u00df\f\u00df\u14f7\t\u00df\u0001\u00e0\u0001\u00e0"+
		"\u0001\u00e0\u0001\u00e0\u0005\u00e0\u14fd\b\u00e0\n\u00e0\f\u00e0\u1500"+
		"\t\u00e0\u0001\u00e0\u0001\u00e0\u0003\u00e0\u1504\b\u00e0\u0001\u00e0"+
		"\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0005\u00e0\u150b\b\u00e0"+
		"\n\u00e0\f\u00e0\u150e\t\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0003"+
		"\u00e0\u1513\b\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001"+
		"\u00e0\u0001\u00e0\u0001\u00e0\u0005\u00e0\u151c\b\u00e0\n\u00e0\f\u00e0"+
		"\u151f\t\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0005\u00e0"+
		"\u1525\b\u00e0\n\u00e0\f\u00e0\u1528\t\u00e0\u0001\u00e0\u0001\u00e0\u0001"+
		"\u00e0\u0003\u00e0\u152d\b\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0003"+
		"\u00e0\u1532\b\u00e0\u0005\u00e0\u1534\b\u00e0\n\u00e0\f\u00e0\u1537\t"+
		"\u00e0\u0003\u00e0\u1539\b\u00e0\u0001\u00e1\u0001\u00e1\u0001\u00e1\u0001"+
		"\u00e1\u0001\u00e1\u0001\u00e1\u0001\u00e1\u0001\u00e1\u0005\u00e1\u1543"+
		"\b\u00e1\n\u00e1\f\u00e1\u1546\t\u00e1\u0001\u00e2\u0001\u00e2\u0001\u00e2"+
		"\u0001\u00e2\u0003\u00e2\u154c\b\u00e2\u0001\u00e2\u0001\u00e2\u0001\u00e2"+
		"\u0003\u00e2\u1551\b\u00e2\u0001\u00e3\u0001\u00e3\u0001\u00e3\u0001\u00e4"+
		"\u0001\u00e4\u0001\u00e4\u0001\u00e4\u0001\u00e4\u0001\u00e4\u0001\u00e4"+
		"\u0001\u00e4\u0001\u00e4\u0001\u00e4\u0001\u00e4\u0001\u00e4\u0001\u00e4"+
		"\u0003\u00e4\u1563\b\u00e4\u0001\u00e4\u0001\u00e4\u0001\u00e4\u0001\u00e4"+
		"\u0001\u00e4\u0001\u00e4\u0005\u00e4\u156b\b\u00e4\n\u00e4\f\u00e4\u156e"+
		"\t\u00e4\u0001\u00e4\u0003\u00e4\u1571\b\u00e4\u0001\u00e5\u0001\u00e5"+
		"\u0001\u00e5\u0003\u00e5\u1576\b\u00e5\u0001\u00e5\u0001\u00e5\u0001\u00e5"+
		"\u0001\u00e5\u0003\u00e5\u157c\b\u00e5\u0001\u00e6\u0001\u00e6\u0001\u00e6"+
		"\u0001\u00e6\u0001\u00e6\u0001\u00e6\u0001\u00e6\u0001\u00e6\u0003\u00e6"+
		"\u1586\b\u00e6\u0001\u00e7\u0001\u00e7\u0001\u00e7\u0001\u00e7\u0001\u00e7"+
		"\u0001\u00e7\u0001\u00e7\u0001\u00e7\u0003\u00e7\u1590\b\u00e7\u0001\u00e8"+
		"\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8"+
		"\u0001\u00e8\u0003\u00e8\u159a\b\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8"+
		"\u0001\u00e8\u0003\u00e8\u15a0\b\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8"+
		"\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0003\u00e8\u15a9\b\u00e8"+
		"\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0003\u00e8\u15af\b\u00e8"+
		"\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0003\u00e8"+
		"\u15b6\b\u00e8\u0003\u00e8\u15b8\b\u00e8\u0001\u00e9\u0001\u00e9\u0001"+
		"\u00e9\u0001\u00ea\u0001\u00ea\u0001\u00ea\u0001\u00ea\u0001\u00ea\u0003"+
		"\u00ea\u15c2\b\u00ea\u0001\u00eb\u0001\u00eb\u0003\u00eb\u15c6\b\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0003\u00eb\u15ca\b\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0003\u00eb\u15d4\b\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0003\u00eb"+
		"\u15d9\b\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0003\u00eb"+
		"\u15eb\b\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0003\u00eb\u1623\b\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0003\u00eb\u163c\b\u00eb\u0001\u00ec\u0001\u00ec"+
		"\u0001\u00ec\u0001\u00ec\u0001\u00ec\u0001\u00ec\u0001\u00ec\u0001\u00ec"+
		"\u0001\u00ec\u0001\u00ec\u0001\u00ec\u0001\u00ec\u0001\u00ec\u0001\u00ec"+
		"\u0001\u00ec\u0001\u00ec\u0003\u00ec\u164e\b\u00ec\u0001\u00ed\u0001\u00ed"+
		"\u0001\u00ed\u0001\u00ed\u0001\u00ee\u0001\u00ee\u0003\u00ee\u1656\b\u00ee"+
		"\u0001\u00ee\u0001\u00ee\u0001\u00ee\u0001\u00ee\u0001\u00ee\u0001\u00ee"+
		"\u0001\u00ee\u0001\u00ee\u0005\u00ee\u1660\b\u00ee\n\u00ee\f\u00ee\u1663"+
		"\t\u00ee\u0001\u00ee\u0001\u00ee\u0001\u00ee\u0001\u00ee\u0003\u00ee\u1669"+
		"\b\u00ee\u0003\u00ee\u166b\b\u00ee\u0001\u00ee\u0001\u00ee\u0001\u00ee"+
		"\u0001\u00ee\u0001\u00ee\u0001\u00ee\u0005\u00ee\u1673\b\u00ee\n\u00ee"+
		"\f\u00ee\u1676\t\u00ee\u0003\u00ee\u1678\b\u00ee\u0001\u00ef\u0001\u00ef"+
		"\u0001\u00ef\u0001\u00ef\u0005\u00ef\u167e\b\u00ef\n\u00ef\f\u00ef\u1681"+
		"\t\u00ef\u0001\u00f0\u0001\u00f0\u0001\u00f0\u0001\u00f0\u0003\u00f0\u1687"+
		"\b\u00f0\u0001\u00f1\u0001\u00f1\u0003\u00f1\u168b\b\u00f1\u0001\u00f1"+
		"\u0001\u00f1\u0001\u00f1\u0003\u00f1\u1690\b\u00f1\u0001\u00f2\u0001\u00f2"+
		"\u0003\u00f2\u1694\b\u00f2\u0001\u00f2\u0001\u00f2\u0001\u00f2\u0003\u00f2"+
		"\u1699\b\u00f2\u0001\u00f2\u0003\u00f2\u169c\b\u00f2\u0001\u00f2\u0003"+
		"\u00f2\u169f\b\u00f2\u0001\u00f3\u0001\u00f3\u0001\u00f3\u0001\u00f3\u0001"+
		"\u00f3\u0001\u00f3\u0001\u00f3\u0003\u00f3\u16a8\b\u00f3\u0001\u00f4\u0001"+
		"\u00f4\u0003\u00f4\u16ac\b\u00f4\u0001\u00f4\u0003\u00f4\u16af\b\u00f4"+
		"\u0001\u00f4\u0001\u00f4\u0003\u00f4\u16b3\b\u00f4\u0001\u00f4\u0001\u00f4"+
		"\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f5\u0001\u00f5"+
		"\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f6\u0001\u00f6"+
		"\u0001\u00f6\u0001\u00f6\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7"+
		"\u0001\u00f7\u0003\u00f7\u16ca\b\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7"+
		"\u0001\u00f7\u0001\u00f7\u0003\u00f7\u16d1\b\u00f7\u0005\u00f7\u16d3\b"+
		"\u00f7\n\u00f7\f\u00f7\u16d6\t\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7"+
		"\u0001\u00f7\u0003\u00f7\u16dc\b\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7"+
		"\u0001\u00f7\u0001\u00f7\u0003\u00f7\u16e3\b\u00f7\u0001\u00f7\u0003\u00f7"+
		"\u16e6\b\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7"+
		"\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7"+
		"\u0001\u00f7\u0005\u00f7\u16f4\b\u00f7\n\u00f7\f\u00f7\u16f7\t\u00f7\u0003"+
		"\u00f7\u16f9\b\u00f7\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001"+
		"\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003\u00f8\u1703\b\u00f8\u0001"+
		"\u00f8\u0001\u00f8\u0003\u00f8\u1707\b\u00f8\u0001\u00f8\u0003\u00f8\u170a"+
		"\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003\u00f8\u170f\b\u00f8"+
		"\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003\u00f8\u1714\b\u00f8\u0001\u00f8"+
		"\u0001\u00f8\u0003\u00f8\u1718\b\u00f8\u0001\u00f8\u0003\u00f8\u171b\b"+
		"\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003\u00f8\u1720\b\u00f8\u0001"+
		"\u00f8\u0001\u00f8\u0001\u00f8\u0003\u00f8\u1725\b\u00f8\u0001\u00f8\u0001"+
		"\u00f8\u0003\u00f8\u1729\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001"+
		"\u00f8\u0001\u00f8\u0003\u00f8\u1730\b\u00f8\u0001\u00f8\u0003\u00f8\u1733"+
		"\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003\u00f8\u1739"+
		"\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001"+
		"\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003\u00f8\u1744\b\u00f8\u0001"+
		"\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001"+
		"\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001"+
		"\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003"+
		"\u00f8\u1758\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001"+
		"\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003"+
		"\u00f8\u1764\b\u00f8\u0001\u00f8\u0003\u00f8\u1767\b\u00f8\u0001\u00f8"+
		"\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8"+
		"\u0001\u00f8\u0003\u00f8\u1771\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8"+
		"\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003\u00f8\u1779\b\u00f8\u0001\u00f8"+
		"\u0001\u00f8\u0003\u00f8\u177d\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8"+
		"\u0001\u00f8\u0001\u00f8\u0003\u00f8\u1784\b\u00f8\u0001\u00f8\u0003\u00f8"+
		"\u1787\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8"+
		"\u0005\u00f8\u178e\b\u00f8\n\u00f8\f\u00f8\u1791\t\u00f8\u0003\u00f8\u1793"+
		"\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003\u00f8\u1798\b\u00f8"+
		"\u0001\u00f8\u0003\u00f8\u179b\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8"+
		"\u0003\u00f8\u17a0\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8"+
		"\u0003\u00f8\u17a6\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8"+
		"\u0001\u00f8\u0003\u00f8\u17ad\b\u00f8\u0001\u00f8\u0001\u00f8\u0001\u00f8"+
		"\u0001\u00f8\u0001\u00f8\u0003\u00f8\u17b4\b\u00f8\u0001\u00f8\u0001\u00f8"+
		"\u0003\u00f8\u17b8\b\u00f8\u0003\u00f8\u17ba\b\u00f8\u0001\u00f9\u0001"+
		"\u00f9\u0003\u00f9\u17be\b\u00f9\u0001\u00f9\u0001\u00f9\u0001\u00f9\u0001"+
		"\u00f9\u0001\u00fa\u0001\u00fa\u0001\u00fa\u0001\u00fa\u0003\u00fa\u17c8"+
		"\b\u00fa\u0001\u00fa\u0003\u00fa\u17cb\b\u00fa\u0001\u00fa\u0003\u00fa"+
		"\u17ce\b\u00fa\u0001\u00fb\u0001\u00fb\u0001\u00fb\u0001\u00fb\u0001\u00fb"+
		"\u0001\u00fb\u0001\u00fb\u0001\u00fb\u0001\u00fb\u0001\u00fb\u0003\u00fb"+
		"\u17da\b\u00fb\u0001\u00fb\u0003\u00fb\u17dd\b\u00fb\u0001\u00fc\u0001"+
		"\u00fc\u0001\u00fc\u0001\u00fc\u0003\u00fc\u17e3\b\u00fc\u0001\u00fd\u0003"+
		"\u00fd\u17e6\b\u00fd\u0001\u00fd\u0001\u00fd\u0001\u00fd\u0001\u00fd\u0001"+
		"\u00fd\u0001\u00fd\u0001\u00fd\u0003\u00fd\u17ef\b\u00fd\u0003\u00fd\u17f1"+
		"\b\u00fd\u0001\u00fd\u0001\u00fd\u0003\u00fd\u17f5\b\u00fd\u0001\u00fd"+
		"\u0001\u00fd\u0001\u00fd\u0001\u00fd\u0001\u00fd\u0001\u00fd\u0001\u00fd"+
		"\u0001\u00fd\u0001\u00fd\u0001\u00fd\u0001\u00fd\u0001\u00fd\u0001\u00fd"+
		"\u0001\u00fd\u0001\u00fd\u0003\u00fd\u1806\b\u00fd\u0001\u00fe\u0001\u00fe"+
		"\u0001\u00fe\u0001\u00fe\u0003\u00fe\u180c\b\u00fe\u0001\u00fe\u0001\u00fe"+
		"\u0003\u00fe\u1810\b\u00fe\u0001\u00ff\u0001\u00ff\u0001\u00ff\u0001\u00ff"+
		"\u0001\u00ff\u0001\u00ff\u0001\u00ff\u0001\u00ff\u0001\u00ff\u0001\u00ff"+
		"\u0001\u00ff\u0001\u00ff\u0003\u00ff\u181e\b\u00ff\u0001\u0100\u0001\u0100"+
		"\u0001\u0100\u0001\u0101\u0001\u0101\u0001\u0101\u0001\u0101\u0001\u0101"+
		"\u0005\u0101\u1828\b\u0101\n\u0101\f\u0101\u182b\t\u0101\u0001\u0101\u0001"+
		"\u0101\u0001\u0101\u0001\u0101\u0003\u0101\u1831\b\u0101\u0001\u0101\u0003"+
		"\u0101\u1834\b\u0101\u0001\u0101\u0001\u0101\u0001\u0101\u0001\u0102\u0001"+
		"\u0102\u0003\u0102\u183b\b\u0102\u0001\u0102\u0001\u0102\u0001\u0102\u0005"+
		"\u0102\u1840\b\u0102\n\u0102\f\u0102\u1843\t\u0102\u0001\u0102\u0001\u0102"+
		"\u0003\u0102\u1847\b\u0102\u0001\u0103\u0001\u0103\u0003\u0103\u184b\b"+
		"\u0103\u0001\u0103\u0001\u0103\u0001\u0104\u0001\u0104\u0001\u0104\u0001"+
		"\u0104\u0001\u0104\u0001\u0104\u0001\u0104\u0005\u0104\u1856\b\u0104\n"+
		"\u0104\f\u0104\u1859\t\u0104\u0001\u0105\u0001\u0105\u0001\u0105\u0001"+
		"\u0105\u0001\u0106\u0001\u0106\u0001\u0107\u0001\u0107\u0003\u0107\u1863"+
		"\b\u0107\u0001\u0107\u0001\u0107\u0001\u0107\u0001\u0107\u0003\u0107\u1869"+
		"\b\u0107\u0001\u0108\u0001\u0108\u0001\u0108\u0003\u0108\u186e\b\u0108"+
		"\u0001\u0108\u0001\u0108\u0001\u0108\u0001\u0108\u0001\u0108\u0001\u0108"+
		"\u0001\u0108\u0001\u0108\u0001\u0108\u0001\u0108\u0001\u0108\u0003\u0108"+
		"\u187b\b\u0108\u0003\u0108\u187d\b\u0108\u0001\u0108\u0001\u0108\u0001"+
		"\u0108\u0003\u0108\u1882\b\u0108\u0001\u0108\u0001\u0108\u0003\u0108\u1886"+
		"\b\u0108\u0001\u0108\u0003\u0108\u1889\b\u0108\u0003\u0108\u188b\b\u0108"+
		"\u0001\u0109\u0001\u0109\u0001\u0109\u0001\u0109\u0001\u0109\u0003\u0109"+
		"\u1892\b\u0109\u0001\u010a\u0001\u010a\u0001\u010a\u0001\u010a\u0001\u010a"+
		"\u0003\u010a\u1899\b\u010a\u0001\u010a\u0003\u010a\u189c\b\u010a\u0001"+
		"\u010a\u0003\u010a\u189f\b\u010a\u0001\u010a\u0001\u010a\u0001\u010a\u0001"+
		"\u010a\u0003\u010a\u18a5\b\u010a\u0001\u010a\u0001\u010a\u0003\u010a\u18a9"+
		"\b\u010a\u0001\u010b\u0001\u010b\u0001\u010b\u0001\u010b\u0003\u010b\u18af"+
		"\b\u010b\u0001\u010c\u0001\u010c\u0001\u010c\u0001\u010c\u0003\u010c\u18b5"+
		"\b\u010c\u0001\u010c\u0001\u010c\u0001\u010d\u0001\u010d\u0001\u010d\u0001"+
		"\u010d\u0001\u010e\u0001\u010e\u0001\u010e\u0001\u010f\u0001\u010f\u0001"+
		"\u010f\u0001\u0110\u0001\u0110\u0001\u0110\u0003\u0110\u18c6\b\u0110\u0001"+
		"\u0110\u0001\u0110\u0001\u0110\u0003\u0110\u18cb\b\u0110\u0001\u0110\u0001"+
		"\u0110\u0001\u0110\u0001\u0110\u0005\u0110\u18d1\b\u0110\n\u0110\f\u0110"+
		"\u18d4\t\u0110\u0003\u0110\u18d6\b\u0110\u0001\u0111\u0001\u0111\u0001"+
		"\u0111\u0003\u0111\u18db\b\u0111\u0001\u0111\u0001\u0111\u0001\u0111\u0003"+
		"\u0111\u18e0\b\u0111\u0001\u0111\u0001\u0111\u0001\u0111\u0001\u0111\u0005"+
		"\u0111\u18e6\b\u0111\n\u0111\f\u0111\u18e9\t\u0111\u0003\u0111\u18eb\b"+
		"\u0111\u0001\u0112\u0001\u0112\u0001\u0112\u0001\u0112\u0001\u0112\u0001"+
		"\u0112\u0003\u0112\u18f3\b\u0112\u0001\u0113\u0001\u0113\u0003\u0113\u18f7"+
		"\b\u0113\u0001\u0113\u0001\u0113\u0001\u0113\u0001\u0113\u0001\u0113\u0001"+
		"\u0113\u0001\u0113\u0001\u0113\u0001\u0113\u0005\u0113\u1902\b\u0113\n"+
		"\u0113\f\u0113\u1905\t\u0113\u0001\u0113\u0001\u0113\u0001\u0113\u0003"+
		"\u0113\u190a\b\u0113\u0001\u0113\u0001\u0113\u0001\u0113\u0001\u0113\u0001"+
		"\u0113\u0001\u0113\u0001\u0113\u0001\u0113\u0005\u0113\u1914\b\u0113\n"+
		"\u0113\f\u0113\u1917\t\u0113\u0003\u0113\u1919\b\u0113\u0001\u0114\u0001"+
		"\u0114\u0001\u0115\u0001\u0115\u0001\u0115\u0001\u0115\u0001\u0115\u0003"+
		"\u0115\u1922\b\u0115\u0001\u0115\u0001\u0115\u0001\u0115\u0003\u0115\u1927"+
		"\b\u0115\u0001\u0116\u0001\u0116\u0001\u0116\u0001\u0116\u0003\u0116\u192d"+
		"\b\u0116\u0001\u0117\u0001\u0117\u0001\u0118\u0001\u0118\u0003\u0118\u1933"+
		"\b\u0118\u0001\u0119\u0001\u0119\u0001\u0119\u0003\u0119\u1938\b\u0119"+
		"\u0003\u0119\u193a\b\u0119\u0001\u0119\u0001\u0119\u0001\u0119\u0003\u0119"+
		"\u193f\b\u0119\u0003\u0119\u1941\b\u0119\u0001\u011a\u0001\u011a\u0003"+
		"\u011a\u1945\b\u011a\u0001\u011a\u0001\u011a\u0001\u011a\u0001\u011a\u0003"+
		"\u011a\u194b\b\u011a\u0001\u011a\u0003\u011a\u194e\b\u011a\u0001\u011a"+
		"\u0003\u011a\u1951\b\u011a\u0001\u011b\u0001\u011b\u0001\u011b\u0001\u011b"+
		"\u0003\u011b\u1957\b\u011b\u0001\u011c\u0001\u011c\u0001\u011d\u0001\u011d"+
		"\u0001\u011d\u0001\u011d\u0001\u011d\u0003\u011d\u1960\b\u011d\u0001\u011e"+
		"\u0001\u011e\u0001\u011f\u0001\u011f\u0001\u011f\u0001\u011f\u0003\u011f"+
		"\u1968\b\u011f\u0001\u0120\u0001\u0120\u0003\u0120\u196c\b\u0120\u0001"+
		"\u0121\u0001\u0121\u0001\u0121\u0003\u0121\u1971\b\u0121\u0001\u0122\u0001"+
		"\u0122\u0001\u0123\u0001\u0123\u0001\u0124\u0001\u0124\u0001\u0124\u0001"+
		"\u0124\u0001\u0124\u0001\u0124\u0001\u0124\u0001\u0124\u0001\u0124\u0001"+
		"\u0124\u0001\u0124\u0001\u0124\u0001\u0124\u0001\u0124\u0004\u0124\u1985"+
		"\b\u0124\u000b\u0124\f\u0124\u1986\u0001\u0125\u0001\u0125\u0001\u0125"+
		"\u0001\u0125\u0001\u0125\u0003\u0125\u198e\b\u0125\u0003\u0125\u1990\b"+
		"\u0125\u0001\u0126\u0001\u0126\u0001\u0126\u0004\u0126\u1995\b\u0126\u000b"+
		"\u0126\f\u0126\u1996\u0003\u0126\u1999\b\u0126\u0001\u0127\u0001\u0127"+
		"\u0003\u0127\u199d\b\u0127\u0001\u0128\u0001\u0128\u0001\u0128\u0003\u0128"+
		"\u19a2\b\u0128\u0001\u0129\u0001\u0129\u0001\u0129\u0001\u0129\u0001\u0129"+
		"\u0001\u0129\u0001\u0129\u0001\u0129\u0001\u0129\u0003\u0129\u19ad\b\u0129"+
		"\u0001\u012a\u0001\u012a\u0001\u012a\u0003\u012a\u19b2\b\u012a\u0001\u012b"+
		"\u0001\u012b\u0001\u012c\u0001\u012c\u0003\u012c\u19b8\b\u012c\u0001\u012d"+
		"\u0003\u012d\u19bb\b\u012d\u0001\u012d\u0001\u012d\u0003\u012d\u19bf\b"+
		"\u012d\u0001\u012d\u0004\u012d\u19c2\b\u012d\u000b\u012d\f\u012d\u19c3"+
		"\u0001\u012d\u0003\u012d\u19c7\b\u012d\u0001\u012d\u0001\u012d\u0003\u012d"+
		"\u19cb\b\u012d\u0001\u012d\u0001\u012d\u0003\u012d\u19cf\b\u012d\u0003"+
		"\u012d\u19d1\b\u012d\u0001\u012e\u0001\u012e\u0001\u012f\u0003\u012f\u19d6"+
		"\b\u012f\u0001\u012f\u0001\u012f\u0001\u0130\u0003\u0130\u19db\b\u0130"+
		"\u0001\u0130\u0001\u0130\u0001\u0131\u0001\u0131\u0001\u0131\u0001\u0131"+
		"\u0001\u0131\u0001\u0131\u0001\u0131\u0001\u0131\u0001\u0131\u0003\u0131"+
		"\u19e8\b\u0131\u0001\u0131\u0003\u0131\u19eb\b\u0131\u0001\u0132\u0001"+
		"\u0132\u0003\u0132\u19ef\b\u0132\u0001\u0132\u0003\u0132\u19f2\b\u0132"+
		"\u0001\u0132\u0003\u0132\u19f5\b\u0132\u0001\u0132\u0001\u0132\u0001\u0132"+
		"\u0003\u0132\u19fa\b\u0132\u0001\u0132\u0001\u0132\u0001\u0132\u0003\u0132"+
		"\u19ff\b\u0132\u0001\u0132\u0001\u0132\u0001\u0132\u0003\u0132\u1a04\b"+
		"\u0132\u0001\u0132\u0003\u0132\u1a07\b\u0132\u0001\u0132\u0001\u0132\u0001"+
		"\u0132\u0003\u0132\u1a0c\b\u0132\u0001\u0132\u0003\u0132\u1a0f\b\u0132"+
		"\u0001\u0132\u0001\u0132\u0001\u0132\u0001\u0132\u0003\u0132\u1a15\b\u0132"+
		"\u0001\u0132\u0003\u0132\u1a18\b\u0132\u0001\u0132\u0001\u0132\u0003\u0132"+
		"\u1a1c\b\u0132\u0001\u0132\u0005\u0132\u1a1f\b\u0132\n\u0132\f\u0132\u1a22"+
		"\t\u0132\u0001\u0132\u0001\u0132\u0003\u0132\u1a26\b\u0132\u0001\u0132"+
		"\u0005\u0132\u1a29\b\u0132\n\u0132\f\u0132\u1a2c\t\u0132\u0001\u0132\u0001"+
		"\u0132\u0003\u0132\u1a30\b\u0132\u0001\u0132\u0003\u0132\u1a33\b\u0132"+
		"\u0001\u0132\u0005\u0132\u1a36\b\u0132\n\u0132\f\u0132\u1a39\t\u0132\u0001"+
		"\u0132\u0001\u0132\u0003\u0132\u1a3d\b\u0132\u0001\u0132\u0005\u0132\u1a40"+
		"\b\u0132\n\u0132\f\u0132\u1a43\t\u0132\u0001\u0132\u0001\u0132\u0001\u0132"+
		"\u0003\u0132\u1a48\b\u0132\u0001\u0132\u0001\u0132\u0001\u0132\u0003\u0132"+
		"\u1a4d\b\u0132\u0001\u0132\u0001\u0132\u0001\u0132\u0003\u0132\u1a52\b"+
		"\u0132\u0001\u0132\u0001\u0132\u0001\u0132\u0003\u0132\u1a57\b\u0132\u0001"+
		"\u0132\u0003\u0132\u1a5a\b\u0132\u0001\u0132\u0001\u0132\u0001\u0132\u0003"+
		"\u0132\u1a5f\b\u0132\u0001\u0132\u0001\u0132\u0003\u0132\u1a63\b\u0132"+
		"\u0001\u0132\u0001\u0132\u0003\u0132\u1a67\b\u0132\u0001\u0133\u0001\u0133"+
		"\u0001\u0133\u0001\u0133\u0005\u0133\u1a6d\b\u0133\n\u0133\f\u0133\u1a70"+
		"\t\u0133\u0001\u0133\u0001\u0133\u0001\u0134\u0001\u0134\u0001\u0135\u0001"+
		"\u0135\u0003\u0135\u1a78\b\u0135\u0001\u0135\u0001\u0135\u0003\u0135\u1a7c"+
		"\b\u0135\u0001\u0135\u0001\u0135\u0001\u0135\u0003\u0135\u1a81\b\u0135"+
		"\u0001\u0135\u0001\u0135\u0001\u0135\u0003\u0135\u1a86\b\u0135\u0001\u0135"+
		"\u0001\u0135\u0003\u0135\u1a8a\b\u0135\u0003\u0135\u1a8c\b\u0135\u0001"+
		"\u0135\u0003\u0135\u1a8f\b\u0135\u0001\u0136\u0001\u0136\u0001\u0136\u0001"+
		"\u0136\u0001\u0137\u0001\u0137\u0001\u0137\u0001\u0137\u0001\u0137\u0001"+
		"\u0137\u0001\u0138\u0001\u0138\u0001\u0138\u0001\u0138\u0003\u0138\u1a9f"+
		"\b\u0138\u0001\u0138\u0001\u0138\u0001\u0139\u0001\u0139\u0001\u0139\u0005"+
		"\u0139\u1aa6\b\u0139\n\u0139\f\u0139\u1aa9\t\u0139\u0001\u013a\u0001\u013a"+
		"\u0001\u013a\u0005\u013a\u1aae\b\u013a\n\u013a\f\u013a\u1ab1\t\u013a\u0001"+
		"\u013b\u0001\u013b\u0001\u013b\u0001\u013b\u0005\u013b\u1ab7\b\u013b\n"+
		"\u013b\f\u013b\u1aba\t\u013b\u0001\u013b\u0001\u013b\u0001\u013c\u0001"+
		"\u013c\u0001\u013c\u0005\u013c\u1ac1\b\u013c\n\u013c\f\u013c\u1ac4\t\u013c"+
		"\u0001\u013d\u0001\u013d\u0001\u013d\u0005\u013d\u1ac9\b\u013d\n\u013d"+
		"\f\u013d\u1acc\t\u013d\u0001\u013e\u0001\u013e\u0001\u013e\u0005\u013e"+
		"\u1ad1\b\u013e\n\u013e\f\u013e\u1ad4\t\u013e\u0001\u013f\u0001\u013f\u0001"+
		"\u013f\u0005\u013f\u1ad9\b\u013f\n\u013f\f\u013f\u1adc\t\u013f\u0001\u0140"+
		"\u0001\u0140\u0001\u0140\u0005\u0140\u1ae1\b\u0140\n\u0140\f\u0140\u1ae4"+
		"\t\u0140\u0001\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001"+
		"\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0003\u0141\u1aef\b\u0141\u0001"+
		"\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0003\u0141\u1af6"+
		"\b\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001"+
		"\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001"+
		"\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0001\u0141\u0003"+
		"\u0141\u1b09\b\u0141\u0001\u0142\u0001\u0142\u0001\u0142\u0003\u0142\u1b0e"+
		"\b\u0142\u0001\u0142\u0003\u0142\u1b11\b\u0142\u0001\u0142\u0001\u0142"+
		"\u0001\u0142\u0003\u0142\u1b16\b\u0142\u0001\u0142\u0003\u0142\u1b19\b"+
		"\u0142\u0001\u0143\u0001\u0143\u0003\u0143\u1b1d\b\u0143\u0001\u0144\u0001"+
		"\u0144\u0001\u0144\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0146\u0001\u0146\u0001\u0146\u0001\u0147\u0001\u0147\u0001\u0147\u0003"+
		"\u0147\u1b2c\b\u0147\u0001\u0148\u0001\u0148\u0001\u0148\u0003\u0148\u1b31"+
		"\b\u0148\u0001\u0149\u0001\u0149\u0001\u0149\u0001\u0149\u0001\u0149\u0001"+
		"\u0149\u0003\u0149\u1b39\b\u0149\u0001\u0149\u0001\u0149\u0001\u0149\u0001"+
		"\u0149\u0001\u0149\u0003\u0149\u1b40\b\u0149\u0001\u0149\u0001\u0149\u0001"+
		"\u0149\u0003\u0149\u1b45\b\u0149\u0001\u014a\u0001\u014a\u0001\u014a\u0003"+
		"\u014a\u1b4a\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\u0001\u014a\u0001"+
		"\u014a\u0004\u014a\u1b69\b\u014a\u000b\u014a\f\u014a\u1b6a\u0001\u014a"+
		"\u0001\u014a\u0003\u014a\u1b6f\b\u014a\u0001\u014a\u0001\u014a\u0001\u014a"+
		"\u0001\u014a\u0004\u014a\u1b75\b\u014a\u000b\u014a\f\u014a\u1b76\u0001"+
		"\u014a\u0001\u014a\u0003\u014a\u1b7b\b\u014a\u0001\u014a\u0001\u014a\u0001"+
		"\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0003\u014a\u1b84"+
		"\b\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001"+
		"\u014a\u0003\u014a\u1b8c\b\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0003"+
		"\u014a\u1b91\b\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001"+
		"\u014a\u0001\u014a\u0003\u014a\u1b99\b\u014a\u0001\u014a\u0001\u014a\u0001"+
		"\u014a\u0003\u014a\u1b9e\b\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0003"+
		"\u014a\u1ba3\b\u014a\u0003\u014a\u1ba5\b\u014a\u0001\u014a\u0001\u014a"+
		"\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0003\u014a"+
		"\u1bae\b\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0003\u014a\u1bb3\b"+
		"\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001"+
		"\u014a\u0003\u014a\u1bbb\b\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0003"+
		"\u014a\u1bc0\b\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001"+
		"\u014a\u0001\u014a\u0003\u014a\u1bc8\b\u014a\u0001\u014a\u0001\u014a\u0001"+
		"\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0003\u014a\u1bd0\b\u014a\u0001"+
		"\u014a\u0003\u014a\u1bd3\b\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001"+
		"\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0003\u014a\u1bdd"+
		"\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\u0003\u014a\u1bef"+
		"\b\u014a\u0001\u014a\u0003\u014a\u1bf2\b\u014a\u0001\u014a\u0003\u014a"+
		"\u1bf5\b\u014a\u0001\u014a\u0001\u014a\u0003\u014a\u1bf9\b\u014a\u0001"+
		"\u014b\u0001\u014b\u0001\u014b\u0001\u014b\u0001\u014b\u0001\u014c\u0001"+
		"\u014c\u0001\u014c\u0001\u014c\u0005\u014c\u1c04\b\u014c\n\u014c\f\u014c"+
		"\u1c07\t\u014c\u0001\u014c\u0001\u014c\u0001\u014c\u0001\u014c\u0001\u014c"+
		"\u0003\u014c\u1c0e\b\u014c\u0001\u014d\u0001\u014d\u0003\u014d\u1c12\b"+
		"\u014d\u0001\u014e\u0001\u014e\u0001\u014e\u0003\u014e\u1c17\b\u014e\u0001"+
		"\u014e\u0001\u014e\u0001\u014e\u0003\u014e\u1c1c\b\u014e\u0001\u014e\u0001"+
		"\u014e\u0001\u014e\u0001\u014e\u0003\u014e\u1c22\b\u014e\u0001\u014e\u0001"+
		"\u014e\u0001\u014e\u0003\u014e\u1c27\b\u014e\u0001\u014e\u0001\u014e\u0003"+
		"\u014e\u1c2b\b\u014e\u0001\u014e\u0001\u014e\u0001\u014e\u0003\u014e\u1c30"+
		"\b\u014e\u0001\u014e\u0001\u014e\u0001\u014e\u0003\u014e\u1c35\b\u014e"+
		"\u0001\u014e\u0001\u014e\u0001\u014e\u0003\u014e\u1c3a\b\u014e\u0001\u014e"+
		"\u0001\u014e\u0001\u014e\u0001\u014e\u0001\u014e\u0001\u014e\u0005\u014e"+
		"\u1c42\b\u014e\n\u014e\f\u014e\u1c45\t\u014e\u0003\u014e\u1c47\b\u014e"+
		"\u0001\u014e\u0001\u014e\u0003\u014e\u1c4b\b\u014e\u0001\u014e\u0001\u014e"+
		"\u0003\u014e\u1c4f\b\u014e\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f"+
		"\u0001\u014f\u0003\u014f\u1c56\b\u014f\u0001\u014f\u0001\u014f\u0003\u014f"+
		"\u1c5a\b\u014f\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f"+
		"\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f"+
		"\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f"+
		"\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f"+
		"\u0001\u014f\u0001\u014f\u0001\u014f\u0001\u014f\u0003\u014f\u1c77\b\u014f"+
		"\u0001\u0150\u0001\u0150\u0001\u0150\u0003\u0150\u1c7c\b\u0150\u0001\u0150"+
		"\u0001\u0150\u0003\u0150\u1c80\b\u0150\u0001\u0151\u0003\u0151\u1c83\b"+
		"\u0151\u0001\u0151\u0003\u0151\u1c86\b\u0151\u0001\u0151\u0003\u0151\u1c89"+
		"\b\u0151\u0001\u0151\u0003\u0151\u1c8c\b\u0151\u0001\u0152\u0001\u0152"+
		"\u0001\u0153\u0001\u0153\u0001\u0153\u0001\u0154\u0001\u0154\u0001\u0155"+
		"\u0001\u0155\u0003\u0155\u1c97\b\u0155\u0001\u0156\u0001\u0156\u0001\u0156"+
		"\u0001\u0156\u0001\u0156\u0001\u0157\u0001\u0157\u0001\u0157\u0001\u0157"+
		"\u0001\u0157\u0001\u0157\u0001\u0157\u0003\u0157\u1ca5\b\u0157\u0001\u0158"+
		"\u0001\u0158\u0001\u0158\u0001\u0158\u0001\u0158\u0005\u0158\u1cac\b\u0158"+
		"\n\u0158\f\u0158\u1caf\t\u0158\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\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0003\u0159\u1cc8\b\u0159\u0001\u015a\u0001\u015a\u0001"+
		"\u015a\u0001\u015a\u0001\u015a\u0001\u015b\u0001\u015b\u0001\u015b\u0001"+
		"\u015b\u0003\u015b\u1cd3\b\u015b\u0001\u015b\u0001\u015b\u0001\u015b\u0001"+
		"\u015b\u0001\u015b\u0003\u015b\u1cda\b\u015b\u0005\u015b\u1cdc\b\u015b"+
		"\n\u015b\f\u015b\u1cdf\t\u015b\u0001\u015c\u0001\u015c\u0001\u015c\u0001"+
		"\u015c\u0003\u015c\u1ce5\b\u015c\u0001\u015d\u0001\u015d\u0001\u015d\u0001"+
		"\u015d\u0001\u015d\u0001\u015d\u0003\u015d\u1ced\b\u015d\u0001\u015d\u0001"+
		"\u015d\u0001\u015d\u0003\u015d\u1cf2\b\u015d\u0001\u015d\u0001\u015d\u0001"+
		"\u015d\u0001\u015d\u0005\u015d\u1cf8\b\u015d\n\u015d\f\u015d\u1cfb\t\u015d"+
		"\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e"+
		"\u0001\u015e\u0001\u015e\u0001\u015e\u0003\u015e\u1d06\b\u015e\u0001\u015e"+
		"\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e"+
		"\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0003\u015e\u1d13\b\u015e"+
		"\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0003\u015e\u1d19\b\u015e"+
		"\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0003\u015e\u1d1f\b\u015e"+
		"\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e"+
		"\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e"+
		"\u0001\u015e\u0001\u015e\u0003\u015e\u1d2f\b\u015e\u0001\u015e\u0001\u015e"+
		"\u0001\u015e\u0001\u015e\u0003\u015e\u1d35\b\u015e\u0001\u015e\u0001\u015e"+
		"\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0005\u015e"+
		"\u1d3e\b\u015e\n\u015e\f\u015e\u1d41\t\u015e\u0001\u015f\u0001\u015f\u0001"+
		"\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001"+
		"\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001"+
		"\u015f\u0001\u015f\u0001\u015f\u0005\u015f\u1d54\b\u015f\n\u015f\f\u015f"+
		"\u1d57\t\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f"+
		"\u0001\u015f\u0001\u015f\u0004\u015f\u1d60\b\u015f\u000b\u015f\f\u015f"+
		"\u1d61\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001"+
		"\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001"+
		"\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0003\u015f\u1d73\b\u015f\u0001"+
		"\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001"+
		"\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001\u015f\u0001"+
		"\u015f\u0001\u015f\u0001\u015f\u0005\u015f\u1d84\b\u015f\n\u015f\f\u015f"+
		"\u1d87\t\u015f\u0001\u0160\u0001\u0160\u0001\u0161\u0001\u0161\u0001\u0161"+
		"\u0001\u0161\u0001\u0161\u0001\u0161\u0001\u0161\u0001\u0161\u0001\u0161"+
		"\u0001\u0161\u0001\u0161\u0001\u0161\u0001\u0161\u0001\u0161\u0003\u0161"+
		"\u1d99\b\u0161\u0001\u0162\u0001\u0162\u0001\u0162\u0001\u0162\u0001\u0162"+
		"\u0001\u0162\u0001\u0162\u0003\u0162\u1da2\b\u0162\u0001\u0163\u0001\u0163"+
		"\u0001\u0163\u0001\u0163\u0001\u0163\u0001\u0163\u0001\u0163\u0003\u0163"+
		"\u1dab\b\u0163\u0001\u0164\u0001\u0164\u0001\u0165\u0001\u0165\u0001\u0165"+
		"\u0001\u0165\u0001\u0165\u0003\u0165\u1db4\b\u0165\u0001\u0166\u0001\u0166"+
		"\u0001\u0167\u0001\u0167\u0001\u0168\u0001\u0168\u0001\u0169\u0001\u0169"+
		"\u0001\u016a\u0001\u016a\u0001\u016b\u0001\u016b\u0001\u016c\u0001\u016c"+
		"\u0001\u016c\u0000\u0003\u02ba\u02bc\u02be\u016d\u0000\u0002\u0004\u0006"+
		"\b\n\f\u000e\u0010\u0012\u0014\u0016\u0018\u001a\u001c\u001e \"$&(*,."+
		"02468:<>@BDFHJLNPRTVXZ\\^`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\u02d2\u02d4\u02d6\u02d8\u0000\u0099\u0002\u0000"+
		"((\u0097\u0097\u0002\u0000\u0214\u0214\u021a\u021a\u0003\u0000EE\u009f"+
		"\u009f\u00b5\u00b5\u0005\u0000++\u0180\u0180\u01c6\u01c6\u01ca\u01ca\u020c"+
		"\u020c\u0004\u0000++\u01a3\u01a3\u0212\u0212\u0265\u0265\u0002\u0000\u0203"+
		"\u0203\u0491\u0491\u0002\u0000NN\u008e\u008e\u0002\u0000\u000f\u000f\u014e"+
		"\u014e\u0003\u0000--UU\u00b8\u00b8\u0002\u0000\u01b2\u01b2\u022f\u022f"+
		"\u0003\u0000\u01fb\u01fb\u028d\u028d\u0296\u0296\u0002\u0000\u0188\u0188"+
		"\u01cc\u01cc\u0002\u0000\u0160\u0160\u01da\u01da\u0002\u0000\u0014\u0014"+
		"\u0479\u0479\u0002\u0000\u00c0\u00c0\u0479\u0479\u0002\u0000++\u0487\u0488"+
		"\u0003\u0000\u015e\u015e\u01bb\u01bb\u025d\u025d\u0002\u0000\u01cb\u01cb"+
		"\u02a5\u02a5\u0002\u0000\u020a\u020a\u02b1\u02b1\u0003\u0000PPTT}}\u0003"+
		"\u0000++\u0192\u0192\u01af\u01af\u0003\u0000++\u018e\u018e\u031f\u031f"+
		"\u0003\u0000\u0280\u0280\u02a4\u02a4\u045e\u045e\u0002\u0000QQ[[\u0003"+
		"\u0000\u01b4\u01b4\u0225\u0225\u0267\u0267\u0002\u0000EE\u009f\u009f\u0001"+
		"\u0000\u0164\u0165\u0001\u0000\u0487\u0488\u0002\u0000\u0491\u0491\u0499"+
		"\u0499\u0002\u0000QQ\u0184\u0184\u0002\u0000\u0222\u0222\u0491\u0491\u0002"+
		"\u0000\u0223\u0223\u0491\u0491\u0003\u0000\u01ae\u01ae\u01d5\u01d5\u020a"+
		"\u020a\u0007\u0000++\u0172\u0172\u0174\u0174\u0192\u0192\u01af\u01af\u023f"+
		"\u023f\u0499\u0499\u0002\u0000\u0203\u0203\u0213\u0213\u0001\u0000\u0488"+
		"\u0489\u0002\u0000\u0005\u000544\u0002\u0000\u001b\u001b\u001f\u001f\u0002"+
		"\u0000\f\f\u00af\u00af\u0002\u0000\u00c0\u00c0\u02a9\u02a9\u0003\u0000"+
		"++\u0180\u0180\u01c6\u01c6\u0002\u0000\u0016\u0016\u0091\u0091\u0003\u0000"+
		",,KKjj\u0002\u0000jj\u0176\u0176\u0002\u0000\u016d\u016d\u01ab\u01ab\u0002"+
		"\u0000ee\u025b\u025b\u0002\u0000,,jj\u0002\u0000\u0006\u000622\u0002\u0000"+
		"\u00bc\u00bc\u02a1\u02a1\u0004\u0000\u01ae\u01ae\u01d5\u01d5\u0209\u0209"+
		"\u0233\u0233\u0002\u0000\u01ae\u01ae\u0209\u0209\u0002\u0000\r\r..\u0003"+
		"\u0000BBNN\u00ba\u00ba\u0002\u0000##SS\u0002\u0000aa\u0095\u0095\u0002"+
		"\u0000\u0006\u000623\u0001\u0000\u0275\u0276\u0002\u0000\u00ac\u00ac\u02ed"+
		"\u02ed\u0002\u0000\u01b7\u01b7\u0263\u0263\u0002\u0000\u00e2\u00e2\u01de"+
		"\u01de\u0005\u0000kk\u01e3\u01e4\u01e6\u01e6\u01ea\u01f2\u0241\u0241\u0004"+
		"\u0000\u01e0\u01e1\u01e5\u01e5\u01e7\u01e8\u0242\u0242\u0003\u0000ll\u01df"+
		"\u01df\u01e9\u01e9\u0002\u0000\u01ce\u01ce\u0277\u0277\u0002\u0000\u0271"+
		"\u0271\u0273\u0273\u0002\u0000\u0158\u0158\u0278\u0278\u0002\u0000ZZ\u0251"+
		"\u0251\u0002\u000044\u0186\u0186\u0003\u0000  ==\u00b3\u00b3\u0003\u0000"+
		"\u0084\u0084\u00ac\u00ac\u01b5\u01b5\u0002\u0000\u00c0\u00c0\u0459\u0459"+
		"\u0003\u0000\f\f\u0014\u0014\u00bb\u00bb\u0002\u0000\f\f\u00bb\u00bb\u0002"+
		"\u0000++yy\u0002\u0000gg\u00b6\u00b6\u0004\u0000\u0168\u0168\u01de\u01de"+
		"\u0268\u0268\u0463\u0463\u0003\u0000))\u0098\u0098\u02a3\u02a3\u0003\u0000"+
		"\u02c3\u02c3\u0466\u0466\u0468\u0468\u0002\u0000ss\u01da\u01da\u0002\u0000"+
		"\u01a6\u01a6\u023a\u023a\u0004\u0000\u00ce\u00ce\u00d0\u00d0\u00d6\u00d6"+
		"\u0281\u0281\u0002\u0000\u0469\u0469\u0479\u0479\u0002\u0000DDPP\u0007"+
		"\u0000\u0084\u0084\u00ac\u00ac\u00b1\u00b1\u019f\u019f\u01b5\u01b5\u0261"+
		"\u0261\u02a3\u02a3\u0002\u0000\u0202\u0202\u027d\u027d\u0002\u0000\u019c"+
		"\u019c\u02a7\u02a7\u0002\u0000\u0084\u0084\u01b5\u01b5\u0003\u0000QQ\\"+
		"\\\u01c4\u01c4\u0002\u0000\u0268\u0268\u0463\u0463\u0001\u0000\u02bf\u02c2"+
		"\u0003\u0000\u01b7\u01b7\u01da\u01da\u0263\u0263\u0002\u0000\u027d\u027d"+
		"\u02a2\u02a2\u0002\u0000\u0159\u0159\u01de\u01de\u0002\u0000\u0269\u0269"+
		"\u0464\u0464\u0002\u0000\u0178\u0178\u0238\u0238\u0006\u0000\u00e2\u00e2"+
		"\u0199\u0199\u019b\u019b\u01b6\u01b6\u0240\u0240\u026a\u026a\u0002\u0000"+
		"./>>\u0003\u0000\u01a6\u01a6\u0227\u0227\u037c\u037c\u0002\u0000\u01d2"+
		"\u01d2\u028f\u028f\n\u0000\u0167\u0167\u016f\u016f\u017a\u017c\u0183\u0183"+
		"\u01fc\u01fc\u0204\u0204\u0282\u0282\u0289\u0289\u034b\u034b\u03f3\u03f3"+
		"\u0002\u0000$$\u00a8\u00a8\u0002\u0000uu\u03ea\u03ea\u000b\u0000\u0167"+
		"\u0167\u016f\u016f\u017a\u017c\u0183\u0183\u01fc\u01fc\u0204\u0204\u0252"+
		"\u0252\u0282\u0282\u0289\u0289\u034b\u034b\u03f3\u03f3\u0002\u0000\u0486"+
		"\u0486\u049b\u049c\u0001\u0000\u049c\u049d\u0002\u0000\u0177\u0177\u031a"+
		"\u0325\u0002\u0000\u0194\u0194\u0491\u0491\u0003\u0000\u0487\u0489\u0492"+
		"\u0492\u0494\u0494\u0002\u0000??\u00b2\u00b2\u0002\u0000tt\u0495\u0495"+
		"\u0005\u0000\u001a\u001a\u00de\u00e0\u00e7\u00e7\u00e9\u00ec\u0207\u0207"+
		"\u0002\u0000\u001a\u001a\u00de\u00df\u0002\u0000\u001a\u001a\u00de\u00de"+
		"\u0001\u0000\u00c4\u00cf\u0003\u0000\u00b7\u00b7\u00c3\u00c3\u0266\u0266"+
		"\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\u009a\u009a\u00ed\u00ed"+
		"\u0002\u0000\u01d2\u01d2\u032a\u0332\u0002\u0000\u00e2\u00e2\u0207\u0207"+
		"\u0005\u0000\u00c8\u00c8\u00ce\u00ce\u00d9\u00da\u00dc\u00dc\u01d2\u01d2"+
		"\u0002\u0000\u00b7\u00b7\u0266\u0266\u0001\u0000\u045a\u045b\u0002\u0000"+
		"\u0209\u0209\u045d\u045d\u0002\u0000\u013b\u013e\u0142\u0142\u0004\u0000"+
		"&&\u0097\u0097\u0139\u013e\u014b\u014b\u0001\u0000\u0145\u0146\u0003\u0000"+
		"\u0012\u0012__\u00b0\u00b0\u0002\u0000\u00de\u00de\u00e2\u00e2\u0002\u0000"+
		"\u00d9\u00da\u00dc\u00dc\u0003\u0000\r\r..\u03e8\u03e8\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\u0086\u0086\u025b"+
		"\u025b\u0002\u0000\u01b1\u01b1\u0230\u0230\u0002\u0000\u0218\u0218\u0228"+
		"\u0228\u0002\u0000rr\u047c\u047c\u0003\u0000??\u00b2\u00b2\u029a\u029a"+
		"\u0002\u0000\u008a\u008a\u0096\u0096\u0003\u0000\u0006\u0006\u0151\u0151"+
		"\u026d\u026d\u0003\u0000rr\u0475\u0476\u047c\u047d\u0001\u0000\u0472\u0478"+
		"\u0002\u0000\u00e2\u00e2\u02f1\u0319\u0001\u0000\u0326\u0329\u0005\u0000"+
		"\u02cc\u02cd\u02dc\u02de\u02e4\u02e4\u02ea\u02eb\u02ed\u02ed\u0001\u0000"+
		"\u02b7\u02be\u0003\u0000\u00d9\u00dd\u00ea\u00ea\u00ed\u00ed3\u0000\u000e"+
		"\u000e\u0011\u0011\u0013\u0013\u001e\u001e$&++1188;;IIOO^^hhnouuyy||\u0082"+
		"\u0083\u009e\u009e\u00a8\u00a8\u00aa\u00aa\u00ef\u00ef\u011b\u0122\u0126"+
		"\u0126\u012a\u012b\u0131\u0138\u014c\u01b0\u01b2\u01ca\u01cc\u0221\u0224"+
		"\u022f\u0231\u0252\u0254\u027f\u0281\u02a4\u02a6\u02a7\u02a9\u02b6\u02bf"+
		"\u02c3\u02c5\u02cb\u02ce\u02cf\u02d4\u02d5\u02d7\u02db\u02df\u02e3\u02e5"+
		"\u02e5\u02e7\u02e9\u02ec\u02ec\u02ee\u02f0\u031f\u031f\u034b\u034b\u0372"+
		"\u0372\u03ee\u03ee\u03f3\u03f3\u0459\u0468\u0017\u0000((aa\u0095\u0095"+
		"\u0097\u0097\u00d9\u00db\u00dd\u00dd\u00fb\u011a\u0122\u0125\u0127\u0129"+
		"\u012c\u0130\u0144\u0144\u01cb\u01cb\u02a5\u02a5\u02b7\u02be\u02e7\u02e7"+
		"\u032a\u032a\u032d\u034a\u034c\u0371\u0373\u03ed\u03ef\u03f2\u03f4\u0458"+
		"\u045a\u045c\u0478\u0478\u232b\u0000\u02db\u0001\u0000\u0000\u0000\u0002"+
		"\u02ee\u0001\u0000\u0000\u0000\u0004\u02fd\u0001\u0000\u0000\u0000\u0006"+
		"\u0308\u0001\u0000\u0000\u0000\b\u0318\u0001\u0000\u0000\u0000\n\u0343"+
		"\u0001\u0000\u0000\u0000\f\u0350\u0001\u0000\u0000\u0000\u000e\u035b\u0001"+
		"\u0000\u0000\u0000\u0010\u036c\u0001\u0000\u0000\u0000\u0012\u0371\u0001"+
		"\u0000\u0000\u0000\u0014\u0380\u0001\u0000\u0000\u0000\u0016\u039c\u0001"+
		"\u0000\u0000\u0000\u0018\u03a5\u0001\u0000\u0000\u0000\u001a\u03a7\u0001"+
		"\u0000\u0000\u0000\u001c\u03b3\u0001\u0000\u0000\u0000\u001e\u03d1\u0001"+
		"\u0000\u0000\u0000 \u03fe\u0001\u0000\u0000\u0000\"\u0431\u0001\u0000"+
		"\u0000\u0000$\u044e\u0001\u0000\u0000\u0000&\u0475\u0001\u0000\u0000\u0000"+
		"(\u0482\u0001\u0000\u0000\u0000*\u04ec\u0001\u0000\u0000\u0000,\u04ee"+
		"\u0001\u0000\u0000\u0000.\u0500\u0001\u0000\u0000\u00000\u053d\u0001\u0000"+
		"\u0000\u00002\u0553\u0001\u0000\u0000\u00004\u0559\u0001\u0000\u0000\u0000"+
		"6\u056f\u0001\u0000\u0000\u00008\u0571\u0001\u0000\u0000\u0000:\u0573"+
		"\u0001\u0000\u0000\u0000<\u05a2\u0001\u0000\u0000\u0000>\u05dc\u0001\u0000"+
		"\u0000\u0000@\u05ff\u0001\u0000\u0000\u0000B\u0606\u0001\u0000\u0000\u0000"+
		"D\u0608\u0001\u0000\u0000\u0000F\u060d\u0001\u0000\u0000\u0000H\u0636"+
		"\u0001\u0000\u0000\u0000J\u063c\u0001\u0000\u0000\u0000L\u063e\u0001\u0000"+
		"\u0000\u0000N\u0653\u0001\u0000\u0000\u0000P\u065a\u0001\u0000\u0000\u0000"+
		"R\u065c\u0001\u0000\u0000\u0000T\u067d\u0001\u0000\u0000\u0000V\u0680"+
		"\u0001\u0000\u0000\u0000X\u0685\u0001\u0000\u0000\u0000Z\u069f\u0001\u0000"+
		"\u0000\u0000\\\u06af\u0001\u0000\u0000\u0000^\u06b1\u0001\u0000\u0000"+
		"\u0000`\u06c1\u0001\u0000\u0000\u0000b\u06c3\u0001\u0000\u0000\u0000d"+
		"\u06ff\u0001\u0000\u0000\u0000f\u0746\u0001\u0000\u0000\u0000h\u0748\u0001"+
		"\u0000\u0000\u0000j\u0764\u0001\u0000\u0000\u0000l\u076c\u0001\u0000\u0000"+
		"\u0000n\u078a\u0001\u0000\u0000\u0000p\u084b\u0001\u0000\u0000\u0000r"+
		"\u084d\u0001\u0000\u0000\u0000t\u084f\u0001\u0000\u0000\u0000v\u0852\u0001"+
		"\u0000\u0000\u0000x\u089c\u0001\u0000\u0000\u0000z\u08b3\u0001\u0000\u0000"+
		"\u0000|\u0947\u0001\u0000\u0000\u0000~\u094c\u0001\u0000\u0000\u0000\u0080"+
		"\u094e\u0001\u0000\u0000\u0000\u0082\u0958\u0001\u0000\u0000\u0000\u0084"+
		"\u0990\u0001\u0000\u0000\u0000\u0086\u09a4\u0001\u0000\u0000\u0000\u0088"+
		"\u09a6\u0001\u0000\u0000\u0000\u008a\u09c9\u0001\u0000\u0000\u0000\u008c"+
		"\u09d2\u0001\u0000\u0000\u0000\u008e\u09d9\u0001\u0000\u0000\u0000\u0090"+
		"\u09f0\u0001\u0000\u0000\u0000\u0092\u09f9\u0001\u0000\u0000\u0000\u0094"+
		"\u0a08\u0001\u0000\u0000\u0000\u0096\u0a24\u0001\u0000\u0000\u0000\u0098"+
		"\u0a38\u0001\u0000\u0000\u0000\u009a\u0a58\u0001\u0000\u0000\u0000\u009c"+
		"\u0ba6\u0001\u0000\u0000\u0000\u009e\u0c10\u0001\u0000\u0000\u0000\u00a0"+
		"\u0c12\u0001\u0000\u0000\u0000\u00a2\u0c19\u0001\u0000\u0000\u0000\u00a4"+
		"\u0c20\u0001\u0000\u0000\u0000\u00a6\u0c3d\u0001\u0000\u0000\u0000\u00a8"+
		"\u0c45\u0001\u0000\u0000\u0000\u00aa\u0c4c\u0001\u0000\u0000\u0000\u00ac"+
		"\u0c53\u0001\u0000\u0000\u0000\u00ae\u0c5a\u0001\u0000\u0000\u0000\u00b0"+
		"\u0c69\u0001\u0000\u0000\u0000\u00b2\u0c73\u0001\u0000\u0000\u0000\u00b4"+
		"\u0c7a\u0001\u0000\u0000\u0000\u00b6\u0c8a\u0001\u0000\u0000\u0000\u00b8"+
		"\u0cb8\u0001\u0000\u0000\u0000\u00ba\u0cba\u0001\u0000\u0000\u0000\u00bc"+
		"\u0ccd\u0001\u0000\u0000\u0000\u00be\u0cda\u0001\u0000\u0000\u0000\u00c0"+
		"\u0ce1\u0001\u0000\u0000\u0000\u00c2\u0ce9\u0001\u0000\u0000\u0000\u00c4"+
		"\u0cf5\u0001\u0000\u0000\u0000\u00c6\u0cf7\u0001\u0000\u0000\u0000\u00c8"+
		"\u0cfe\u0001\u0000\u0000\u0000\u00ca\u0d00\u0001\u0000\u0000\u0000\u00cc"+
		"\u0d33\u0001\u0000\u0000\u0000\u00ce\u0d7d\u0001\u0000\u0000\u0000\u00d0"+
		"\u0db8\u0001\u0000\u0000\u0000\u00d2\u0e17\u0001\u0000\u0000\u0000\u00d4"+
		"\u0e1b\u0001\u0000\u0000\u0000\u00d6\u0e1d\u0001\u0000\u0000\u0000\u00d8"+
		"\u0e40\u0001\u0000\u0000\u0000\u00da\u0e42\u0001\u0000\u0000\u0000\u00dc"+
		"\u0e4a\u0001\u0000\u0000\u0000\u00de\u0e52\u0001\u0000\u0000\u0000\u00e0"+
		"\u0e57\u0001\u0000\u0000\u0000\u00e2\u0e75\u0001\u0000\u0000\u0000\u00e4"+
		"\u0eac\u0001\u0000\u0000\u0000\u00e6\u0eb5\u0001\u0000\u0000\u0000\u00e8"+
		"\u0ec9\u0001\u0000\u0000\u0000\u00ea\u0ed5\u0001\u0000\u0000\u0000\u00ec"+
		"\u0ed9\u0001\u0000\u0000\u0000\u00ee\u0efa\u0001\u0000\u0000\u0000\u00f0"+
		"\u0f0f\u0001\u0000\u0000\u0000\u00f2\u0f19\u0001\u0000\u0000\u0000\u00f4"+
		"\u0f1d\u0001\u0000\u0000\u0000\u00f6\u0f37\u0001\u0000\u0000\u0000\u00f8"+
		"\u0f61\u0001\u0000\u0000\u0000\u00fa\u0f63\u0001\u0000\u0000\u0000\u00fc"+
		"\u0f72\u0001\u0000\u0000\u0000\u00fe\u0fa6\u0001\u0000\u0000\u0000\u0100"+
		"\u0fb0\u0001\u0000\u0000\u0000\u0102\u0fba\u0001\u0000\u0000\u0000\u0104"+
		"\u0ff6\u0001\u0000\u0000\u0000\u0106\u0ff8\u0001\u0000\u0000\u0000\u0108"+
		"\u1012\u0001\u0000\u0000\u0000\u010a\u1018\u0001\u0000\u0000\u0000\u010c"+
		"\u1020\u0001\u0000\u0000\u0000\u010e\u1031\u0001\u0000\u0000\u0000\u0110"+
		"\u1041\u0001\u0000\u0000\u0000\u0112\u1066\u0001\u0000\u0000\u0000\u0114"+
		"\u106c\u0001\u0000\u0000\u0000\u0116\u1075\u0001\u0000\u0000\u0000\u0118"+
		"\u1082\u0001\u0000\u0000\u0000\u011a\u1086\u0001\u0000\u0000\u0000\u011c"+
		"\u10ac\u0001\u0000\u0000\u0000\u011e\u10d2\u0001\u0000\u0000\u0000\u0120"+
		"\u10e0\u0001\u0000\u0000\u0000\u0122\u10e8\u0001\u0000\u0000\u0000\u0124"+
		"\u10ec\u0001\u0000\u0000\u0000\u0126\u10f2\u0001\u0000\u0000\u0000\u0128"+
		"\u1100\u0001\u0000\u0000\u0000\u012a\u1103\u0001\u0000\u0000\u0000\u012c"+
		"\u1115\u0001\u0000\u0000\u0000\u012e\u1119\u0001\u0000\u0000\u0000\u0130"+
		"\u1129\u0001\u0000\u0000\u0000\u0132\u112b\u0001\u0000\u0000\u0000\u0134"+
		"\u1137\u0001\u0000\u0000\u0000\u0136\u113b\u0001\u0000\u0000\u0000\u0138"+
		"\u114c\u0001\u0000\u0000\u0000\u013a\u115d\u0001\u0000\u0000\u0000\u013c"+
		"\u1160\u0001\u0000\u0000\u0000\u013e\u116a\u0001\u0000\u0000\u0000\u0140"+
		"\u116e\u0001\u0000\u0000\u0000\u0142\u117b\u0001\u0000\u0000\u0000\u0144"+
		"\u117e\u0001\u0000\u0000\u0000\u0146\u1183\u0001\u0000\u0000\u0000\u0148"+
		"\u1197\u0001\u0000\u0000\u0000\u014a\u1199\u0001\u0000\u0000\u0000\u014c"+
		"\u11aa\u0001\u0000\u0000\u0000\u014e\u11b3\u0001\u0000\u0000\u0000\u0150"+
		"\u11bc\u0001\u0000\u0000\u0000\u0152\u11be\u0001\u0000\u0000\u0000\u0154"+
		"\u11cc\u0001\u0000\u0000\u0000\u0156\u11d7\u0001\u0000\u0000\u0000\u0158"+
		"\u11e0\u0001\u0000\u0000\u0000\u015a\u11e3\u0001\u0000\u0000\u0000\u015c"+
		"\u11eb\u0001\u0000\u0000\u0000\u015e\u1204\u0001\u0000\u0000\u0000\u0160"+
		"\u1210\u0001\u0000\u0000\u0000\u0162\u1213\u0001\u0000\u0000\u0000\u0164"+
		"\u1233\u0001\u0000\u0000\u0000\u0166\u1235\u0001\u0000\u0000\u0000\u0168"+
		"\u1237\u0001\u0000\u0000\u0000\u016a\u1239\u0001\u0000\u0000\u0000\u016c"+
		"\u123b\u0001\u0000\u0000\u0000\u016e\u1270\u0001\u0000\u0000\u0000\u0170"+
		"\u1272\u0001\u0000\u0000\u0000\u0172\u1278\u0001\u0000\u0000\u0000\u0174"+
		"\u128c\u0001\u0000\u0000\u0000\u0176\u129a\u0001\u0000\u0000\u0000\u0178"+
		"\u12a5\u0001\u0000\u0000\u0000\u017a\u12a7\u0001\u0000\u0000\u0000\u017c"+
		"\u12ad\u0001\u0000\u0000\u0000\u017e\u12b7\u0001\u0000\u0000\u0000\u0180"+
		"\u12bb\u0001\u0000\u0000\u0000\u0182\u12c2\u0001\u0000\u0000\u0000\u0184"+
		"\u12c6\u0001\u0000\u0000\u0000\u0186\u12cc\u0001\u0000\u0000\u0000\u0188"+
		"\u12d3\u0001\u0000\u0000\u0000\u018a\u12d9\u0001\u0000\u0000\u0000\u018c"+
		"\u12df\u0001\u0000\u0000\u0000\u018e\u12e4\u0001\u0000\u0000\u0000\u0190"+
		"\u1313\u0001\u0000\u0000\u0000\u0192\u1328\u0001\u0000\u0000\u0000\u0194"+
		"\u1341\u0001\u0000\u0000\u0000\u0196\u1344\u0001\u0000\u0000\u0000\u0198"+
		"\u134a\u0001\u0000\u0000\u0000\u019a\u135a\u0001\u0000\u0000\u0000\u019c"+
		"\u1369\u0001\u0000\u0000\u0000\u019e\u136f\u0001\u0000\u0000\u0000\u01a0"+
		"\u138d\u0001\u0000\u0000\u0000\u01a2\u138f\u0001\u0000\u0000\u0000\u01a4"+
		"\u1396\u0001\u0000\u0000\u0000\u01a6\u13a2\u0001\u0000\u0000\u0000\u01a8"+
		"\u13a8\u0001\u0000\u0000\u0000\u01aa\u13c1\u0001\u0000\u0000\u0000\u01ac"+
		"\u13c5\u0001\u0000\u0000\u0000\u01ae\u13c9\u0001\u0000\u0000\u0000\u01b0"+
		"\u13d4\u0001\u0000\u0000\u0000\u01b2\u1418\u0001\u0000\u0000\u0000\u01b4"+
		"\u1456\u0001\u0000\u0000\u0000\u01b6\u1458\u0001\u0000\u0000\u0000\u01b8"+
		"\u14c2\u0001\u0000\u0000\u0000\u01ba\u14da\u0001\u0000\u0000\u0000\u01bc"+
		"\u14dc\u0001\u0000\u0000\u0000\u01be\u14ee\u0001\u0000\u0000\u0000\u01c0"+
		"\u1538\u0001\u0000\u0000\u0000\u01c2\u153a\u0001\u0000\u0000\u0000\u01c4"+
		"\u1547\u0001\u0000\u0000\u0000\u01c6\u1552\u0001\u0000\u0000\u0000\u01c8"+
		"\u1570\u0001\u0000\u0000\u0000\u01ca\u157b\u0001\u0000\u0000\u0000\u01cc"+
		"\u1585\u0001\u0000\u0000\u0000\u01ce\u158f\u0001\u0000\u0000\u0000\u01d0"+
		"\u15b7\u0001\u0000\u0000\u0000\u01d2\u15b9\u0001\u0000\u0000\u0000\u01d4"+
		"\u15bc\u0001\u0000\u0000\u0000\u01d6\u163b\u0001\u0000\u0000\u0000\u01d8"+
		"\u164d\u0001\u0000\u0000\u0000\u01da\u164f\u0001\u0000\u0000\u0000\u01dc"+
		"\u1653\u0001\u0000\u0000\u0000\u01de\u1679\u0001\u0000\u0000\u0000\u01e0"+
		"\u1682\u0001\u0000\u0000\u0000\u01e2\u1688\u0001\u0000\u0000\u0000\u01e4"+
		"\u1691\u0001\u0000\u0000\u0000\u01e6\u16a7\u0001\u0000\u0000\u0000\u01e8"+
		"\u16a9\u0001\u0000\u0000\u0000\u01ea\u16ba\u0001\u0000\u0000\u0000\u01ec"+
		"\u16c0\u0001\u0000\u0000\u0000\u01ee\u16f8\u0001\u0000\u0000\u0000\u01f0"+
		"\u17b9\u0001\u0000\u0000\u0000\u01f2\u17bb\u0001\u0000\u0000\u0000\u01f4"+
		"\u17cd\u0001\u0000\u0000\u0000\u01f6\u17dc\u0001\u0000\u0000\u0000\u01f8"+
		"\u17e2\u0001\u0000\u0000\u0000\u01fa\u1805\u0001\u0000\u0000\u0000\u01fc"+
		"\u180f\u0001\u0000\u0000\u0000\u01fe\u181d\u0001\u0000\u0000\u0000\u0200"+
		"\u181f\u0001\u0000\u0000\u0000\u0202\u1822\u0001\u0000\u0000\u0000\u0204"+
		"\u1846\u0001\u0000\u0000\u0000\u0206\u1848\u0001\u0000\u0000\u0000\u0208"+
		"\u184e\u0001\u0000\u0000\u0000\u020a\u185a\u0001\u0000\u0000\u0000\u020c"+
		"\u185e\u0001\u0000\u0000\u0000\u020e\u1860\u0001\u0000\u0000\u0000\u0210"+
		"\u188a\u0001\u0000\u0000\u0000\u0212\u1891\u0001\u0000\u0000\u0000\u0214"+
		"\u1893\u0001\u0000\u0000\u0000\u0216\u18aa\u0001\u0000\u0000\u0000\u0218"+
		"\u18b0\u0001\u0000\u0000\u0000\u021a\u18b8\u0001\u0000\u0000\u0000\u021c"+
		"\u18bc\u0001\u0000\u0000\u0000\u021e\u18bf\u0001\u0000\u0000\u0000\u0220"+
		"\u18c2\u0001\u0000\u0000\u0000\u0222\u18d7\u0001\u0000\u0000\u0000\u0224"+
		"\u18ec\u0001\u0000\u0000\u0000\u0226\u18f4\u0001\u0000\u0000\u0000\u0228"+
		"\u191a\u0001\u0000\u0000\u0000\u022a\u1926\u0001\u0000\u0000\u0000\u022c"+
		"\u1928\u0001\u0000\u0000\u0000\u022e\u192e\u0001\u0000\u0000\u0000\u0230"+
		"\u1932\u0001\u0000\u0000\u0000\u0232\u1940\u0001\u0000\u0000\u0000\u0234"+
		"\u194d\u0001\u0000\u0000\u0000\u0236\u1956\u0001\u0000\u0000\u0000\u0238"+
		"\u1958\u0001\u0000\u0000\u0000\u023a\u195f\u0001\u0000\u0000\u0000\u023c"+
		"\u1961\u0001\u0000\u0000\u0000\u023e\u1967\u0001\u0000\u0000\u0000\u0240"+
		"\u196b\u0001\u0000\u0000\u0000\u0242\u1970\u0001\u0000\u0000\u0000\u0244"+
		"\u1972\u0001\u0000\u0000\u0000\u0246\u1974\u0001\u0000\u0000\u0000\u0248"+
		"\u1976\u0001\u0000\u0000\u0000\u024a\u1988\u0001\u0000\u0000\u0000\u024c"+
		"\u1998\u0001\u0000\u0000\u0000\u024e\u199c\u0001\u0000\u0000\u0000\u0250"+
		"\u19a1\u0001\u0000\u0000\u0000\u0252\u19ac\u0001\u0000\u0000\u0000\u0254"+
		"\u19b1\u0001\u0000\u0000\u0000\u0256\u19b3\u0001\u0000\u0000\u0000\u0258"+
		"\u19b7\u0001\u0000\u0000\u0000\u025a\u19d0\u0001\u0000\u0000\u0000\u025c"+
		"\u19d2\u0001\u0000\u0000\u0000\u025e\u19d5\u0001\u0000\u0000\u0000\u0260"+
		"\u19da\u0001\u0000\u0000\u0000\u0262\u19ea\u0001\u0000\u0000\u0000\u0264"+
		"\u1a66\u0001\u0000\u0000\u0000\u0266\u1a68\u0001\u0000\u0000\u0000\u0268"+
		"\u1a73\u0001\u0000\u0000\u0000\u026a\u1a8b\u0001\u0000\u0000\u0000\u026c"+
		"\u1a90\u0001\u0000\u0000\u0000\u026e\u1a94\u0001\u0000\u0000\u0000\u0270"+
		"\u1a9a\u0001\u0000\u0000\u0000\u0272\u1aa2\u0001\u0000\u0000\u0000\u0274"+
		"\u1aaa\u0001\u0000\u0000\u0000\u0276\u1ab2\u0001\u0000\u0000\u0000\u0278"+
		"\u1abd\u0001\u0000\u0000\u0000\u027a\u1ac5\u0001\u0000\u0000\u0000\u027c"+
		"\u1acd\u0001\u0000\u0000\u0000\u027e\u1ad5\u0001\u0000\u0000\u0000\u0280"+
		"\u1add\u0001\u0000\u0000\u0000\u0282\u1b08\u0001\u0000\u0000\u0000\u0284"+
		"\u1b18\u0001\u0000\u0000\u0000\u0286\u1b1c\u0001\u0000\u0000\u0000\u0288"+
		"\u1b1e\u0001\u0000\u0000\u0000\u028a\u1b21\u0001\u0000\u0000\u0000\u028c"+
		"\u1b25\u0001\u0000\u0000\u0000\u028e\u1b2b\u0001\u0000\u0000\u0000\u0290"+
		"\u1b30\u0001\u0000\u0000\u0000\u0292\u1b44\u0001\u0000\u0000\u0000\u0294"+
		"\u1bf8\u0001\u0000\u0000\u0000\u0296\u1bfa\u0001\u0000\u0000\u0000\u0298"+
		"\u1c0d\u0001\u0000\u0000\u0000\u029a\u1c0f\u0001\u0000\u0000\u0000\u029c"+
		"\u1c4e\u0001\u0000\u0000\u0000\u029e\u1c76\u0001\u0000\u0000\u0000\u02a0"+
		"\u1c78\u0001\u0000\u0000\u0000\u02a2\u1c82\u0001\u0000\u0000\u0000\u02a4"+
		"\u1c8d\u0001\u0000\u0000\u0000\u02a6\u1c8f\u0001\u0000\u0000\u0000\u02a8"+
		"\u1c92\u0001\u0000\u0000\u0000\u02aa\u1c96\u0001\u0000\u0000\u0000\u02ac"+
		"\u1c98\u0001\u0000\u0000\u0000\u02ae\u1ca4\u0001\u0000\u0000\u0000\u02b0"+
		"\u1ca6\u0001\u0000\u0000\u0000\u02b2\u1cc7\u0001\u0000\u0000\u0000\u02b4"+
		"\u1cc9\u0001\u0000\u0000\u0000\u02b6\u1cd2\u0001\u0000\u0000\u0000\u02b8"+
		"\u1ce4\u0001\u0000\u0000\u0000\u02ba\u1cf1\u0001\u0000\u0000\u0000\u02bc"+
		"\u1cfc\u0001\u0000\u0000\u0000\u02be\u1d72\u0001\u0000\u0000\u0000\u02c0"+
		"\u1d88\u0001\u0000\u0000\u0000\u02c2\u1d98\u0001\u0000\u0000\u0000\u02c4"+
		"\u1da1\u0001\u0000\u0000\u0000\u02c6\u1daa\u0001\u0000\u0000\u0000\u02c8"+
		"\u1dac\u0001\u0000\u0000\u0000\u02ca\u1db3\u0001\u0000\u0000\u0000\u02cc"+
		"\u1db5\u0001\u0000\u0000\u0000\u02ce\u1db7\u0001\u0000\u0000\u0000\u02d0"+
		"\u1db9\u0001\u0000\u0000\u0000\u02d2\u1dbb\u0001\u0000\u0000\u0000\u02d4"+
		"\u1dbd\u0001\u0000\u0000\u0000\u02d6\u1dbf\u0001\u0000\u0000\u0000\u02d8"+
		"\u1dc1\u0001\u0000\u0000\u0000\u02da\u02dc\u0003\u0002\u0001\u0000\u02db"+
		"\u02da\u0001\u0000\u0000\u0000\u02db\u02dc\u0001\u0000\u0000\u0000\u02dc"+
		"\u02df\u0001\u0000\u0000\u0000\u02dd\u02de\u0005\u0476\u0000\u0000\u02de"+
		"\u02e0\u0005\u0476\u0000\u0000\u02df\u02dd\u0001\u0000\u0000\u0000\u02df"+
		"\u02e0\u0001\u0000\u0000\u0000\u02e0\u02e1\u0001\u0000\u0000\u0000\u02e1"+
		"\u02e2\u0005\u0000\u0000\u0001\u02e2\u0001\u0001\u0000\u0000\u0000\u02e3"+
		"\u02e6\u0003\u0004\u0002\u0000\u02e4\u02e5\u0005\u0476\u0000\u0000\u02e5"+
		"\u02e7\u0005\u0476\u0000\u0000\u02e6\u02e4\u0001\u0000\u0000\u0000\u02e6"+
		"\u02e7\u0001\u0000\u0000\u0000\u02e7\u02e9\u0001\u0000\u0000\u0000\u02e8"+
		"\u02ea\u0005\u0485\u0000\u0000\u02e9\u02e8\u0001\u0000\u0000\u0000\u02e9"+
		"\u02ea\u0001\u0000\u0000\u0000\u02ea\u02ed\u0001\u0000\u0000\u0000\u02eb"+
		"\u02ed\u0003\b\u0004\u0000\u02ec\u02e3\u0001\u0000\u0000\u0000\u02ec\u02eb"+
		"\u0001\u0000\u0000\u0000\u02ed\u02f0\u0001\u0000\u0000\u0000\u02ee\u02ec"+
		"\u0001\u0000\u0000\u0000\u02ee\u02ef\u0001\u0000\u0000\u0000\u02ef\u02fa"+
		"\u0001\u0000\u0000\u0000\u02f0\u02ee\u0001\u0000\u0000\u0000\u02f1\u02f7"+
		"\u0003\u0004\u0002\u0000\u02f2\u02f3\u0005\u0476\u0000\u0000\u02f3\u02f5"+
		"\u0005\u0476\u0000\u0000\u02f4\u02f2\u0001\u0000\u0000\u0000\u02f4\u02f5"+
		"\u0001\u0000\u0000\u0000\u02f5\u02f6\u0001\u0000\u0000\u0000\u02f6\u02f8"+
		"\u0005\u0485\u0000\u0000\u02f7\u02f4\u0001\u0000\u0000\u0000\u02f7\u02f8"+
		"\u0001\u0000\u0000\u0000\u02f8\u02fb\u0001\u0000\u0000\u0000\u02f9\u02fb"+
		"\u0003\b\u0004\u0000\u02fa\u02f1\u0001\u0000\u0000\u0000\u02fa\u02f9\u0001"+
		"\u0000\u0000\u0000\u02fb\u0003\u0001\u0000\u0000\u0000\u02fc\u02fe\u0003"+
		"\u0006\u0003\u0000\u02fd\u02fc\u0001\u0000\u0000\u0000\u02fd\u02fe\u0001"+
		"\u0000\u0000\u0000\u02fe\u0306\u0001\u0000\u0000\u0000\u02ff\u0307\u0003"+
		"\n\u0005\u0000\u0300\u0307\u0003\f\u0006\u0000\u0301\u0307\u0003\u000e"+
		"\u0007\u0000\u0302\u0307\u0003\u0010\b\u0000\u0303\u0307\u0003\u0012\t"+
		"\u0000\u0304\u0307\u0003\u0016\u000b\u0000\u0305\u0307\u0003\u0018\f\u0000"+
		"\u0306\u02ff\u0001\u0000\u0000\u0000\u0306\u0300\u0001\u0000\u0000\u0000"+
		"\u0306\u0301\u0001\u0000\u0000\u0000\u0306\u0302\u0001\u0000\u0000\u0000"+
		"\u0306\u0303\u0001\u0000\u0000\u0000\u0306\u0304\u0001\u0000\u0000\u0000"+
		"\u0306\u0305\u0001\u0000\u0000\u0000\u0307\u0005\u0001\u0000\u0000\u0000"+
		"\u0308\u0309\u0005\u009a\u0000\u0000\u0309\u030a\u0005\u00aa\u0000\u0000"+
		"\u030a\u030b\u0005\u0499\u0000\u0000\u030b\u030c\u0005\u0479\u0000\u0000"+
		"\u030c\u0313\u0003\u0262\u0131\u0000\u030d\u030e\u0005\u0484\u0000\u0000"+
		"\u030e\u030f\u0005\u0499\u0000\u0000\u030f\u0310\u0005\u0479\u0000\u0000"+
		"\u0310\u0312\u0003\u0262\u0131\u0000\u0311\u030d\u0001\u0000\u0000\u0000"+
		"\u0312\u0315\u0001\u0000\u0000\u0000\u0313\u0311\u0001\u0000\u0000\u0000"+
		"\u0313\u0314\u0001\u0000\u0000\u0000\u0314\u0316\u0001\u0000\u0000\u0000"+
		"\u0315\u0313\u0001\u0000\u0000\u0000\u0316\u0317\u0005A\u0000\u0000\u0317"+
		"\u0007\u0001\u0000\u0000\u0000\u0318\u0319\u0005\u0485\u0000\u0000\u0319"+
		"\t\u0001\u0000\u0000\u0000\u031a\u0344\u0003\u001a\r\u0000\u031b\u0344"+
		"\u0003\u001c\u000e\u0000\u031c\u0344\u0003\u001e\u000f\u0000\u031d\u0344"+
		"\u0003 \u0010\u0000\u031e\u0344\u0003\"\u0011\u0000\u031f\u0344\u0003"+
		"$\u0012\u0000\u0320\u0344\u0003(\u0014\u0000\u0321\u0344\u0003*\u0015"+
		"\u0000\u0322\u0344\u0003,\u0016\u0000\u0323\u0344\u0003.\u0017\u0000\u0324"+
		"\u0344\u00030\u0018\u0000\u0325\u0344\u0003:\u001d\u0000\u0326\u0344\u0003"+
		"&\u0013\u0000\u0327\u0344\u0003<\u001e\u0000\u0328\u0344\u0003\u0086C"+
		"\u0000\u0329\u0344\u0003\u0088D\u0000\u032a\u0344\u0003\u008aE\u0000\u032b"+
		"\u0344\u0003\u008cF\u0000\u032c\u0344\u0003\u008eG\u0000\u032d\u0344\u0003"+
		"\u0090H\u0000\u032e\u0344\u0003\u0092I\u0000\u032f\u0344\u0003\u0094J"+
		"\u0000\u0330\u0344\u0003\u0096K\u0000\u0331\u0344\u0003\u0098L\u0000\u0332"+
		"\u0344\u0003\u009aM\u0000\u0333\u0344\u0003\u00a0P\u0000\u0334\u0344\u0003"+
		"\u00a2Q\u0000\u0335\u0344\u0003\u00a4R\u0000\u0336\u0344\u0003\u00a6S"+
		"\u0000\u0337\u0344\u0003\u00a8T\u0000\u0338\u0344\u0003\u00aaU\u0000\u0339"+
		"\u0344\u0003\u00acV\u0000\u033a\u0344\u0003\u00aeW\u0000\u033b\u0344\u0003"+
		"\u00b0X\u0000\u033c\u0344\u0003\u00b2Y\u0000\u033d\u0344\u0003\u00b4Z"+
		"\u0000\u033e\u0344\u0003\u00b6[\u0000\u033f\u0344\u0003\u00ba]\u0000\u0340"+
		"\u0344\u0003\u00b8\\\u0000\u0341\u0344\u0003\u00bc^\u0000\u0342\u0344"+
		"\u0003\u00c0`\u0000\u0343\u031a\u0001\u0000\u0000\u0000\u0343\u031b\u0001"+
		"\u0000\u0000\u0000\u0343\u031c\u0001\u0000\u0000\u0000\u0343\u031d\u0001"+
		"\u0000\u0000\u0000\u0343\u031e\u0001\u0000\u0000\u0000\u0343\u031f\u0001"+
		"\u0000\u0000\u0000\u0343\u0320\u0001\u0000\u0000\u0000\u0343\u0321\u0001"+
		"\u0000\u0000\u0000\u0343\u0322\u0001\u0000\u0000\u0000\u0343\u0323\u0001"+
		"\u0000\u0000\u0000\u0343\u0324\u0001\u0000\u0000\u0000\u0343\u0325\u0001"+
		"\u0000\u0000\u0000\u0343\u0326\u0001\u0000\u0000\u0000\u0343\u0327\u0001"+
		"\u0000\u0000\u0000\u0343\u0328\u0001\u0000\u0000\u0000\u0343\u0329\u0001"+
		"\u0000\u0000\u0000\u0343\u032a\u0001\u0000\u0000\u0000\u0343\u032b\u0001"+
		"\u0000\u0000\u0000\u0343\u032c\u0001\u0000\u0000\u0000\u0343\u032d\u0001"+
		"\u0000\u0000\u0000\u0343\u032e\u0001\u0000\u0000\u0000\u0343\u032f\u0001"+
		"\u0000\u0000\u0000\u0343\u0330\u0001\u0000\u0000\u0000\u0343\u0331\u0001"+
		"\u0000\u0000\u0000\u0343\u0332\u0001\u0000\u0000\u0000\u0343\u0333\u0001"+
		"\u0000\u0000\u0000\u0343\u0334\u0001\u0000\u0000\u0000\u0343\u0335\u0001"+
		"\u0000\u0000\u0000\u0343\u0336\u0001\u0000\u0000\u0000\u0343\u0337\u0001"+
		"\u0000\u0000\u0000\u0343\u0338\u0001\u0000\u0000\u0000\u0343\u0339\u0001"+
		"\u0000\u0000\u0000\u0343\u033a\u0001\u0000\u0000\u0000\u0343\u033b\u0001"+
		"\u0000\u0000\u0000\u0343\u033c\u0001\u0000\u0000\u0000\u0343\u033d\u0001"+
		"\u0000\u0000\u0000\u0343\u033e\u0001\u0000\u0000\u0000\u0343\u033f\u0001"+
		"\u0000\u0000\u0000\u0343\u0340\u0001\u0000\u0000\u0000\u0343\u0341\u0001"+
		"\u0000\u0000\u0000\u0343\u0342\u0001\u0000\u0000\u0000\u0344\u000b\u0001"+
		"\u0000\u0000\u0000\u0345\u0351\u0003\u00d2i\u0000\u0346\u0351\u0003\u00ca"+
		"e\u0000\u0347\u0351\u0003\u00d4j\u0000\u0348\u0351\u0003\u00c4b\u0000"+
		"\u0349\u0351\u0003\u00d0h\u0000\u034a\u0351\u0003\u00c2a\u0000\u034b\u0351"+
		"\u0003\u00ccf\u0000\u034c\u0351\u0003\u00ceg\u0000\u034d\u0351\u0003\u00c6"+
		"c\u0000\u034e\u0351\u0003\u00c8d\u0000\u034f\u0351\u0003\u00d6k\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\r\u0001\u0000\u0000\u0000\u0352"+
		"\u035c\u0003\u0132\u0099\u0000\u0353\u035c\u0003\u0134\u009a\u0000\u0354"+
		"\u035c\u0003\u0136\u009b\u0000\u0355\u035c\u0003\u0138\u009c\u0000\u0356"+
		"\u035c\u0003\u013a\u009d\u0000\u0357\u035c\u0003\u013c\u009e\u0000\u0358"+
		"\u035c\u0003\u013e\u009f\u0000\u0359\u035c\u0003\u0140\u00a0\u0000\u035a"+
		"\u035c\u0003\u0142\u00a1\u0000\u035b\u0352\u0001\u0000\u0000\u0000\u035b"+
		"\u0353\u0001\u0000\u0000\u0000\u035b\u0354\u0001\u0000\u0000\u0000\u035b"+
		"\u0355\u0001\u0000\u0000\u0000\u035b\u0356\u0001\u0000\u0000\u0000\u035b"+
		"\u0357\u0001\u0000\u0000\u0000\u035b\u0358\u0001\u0000\u0000\u0000\u035b"+
		"\u0359\u0001\u0000\u0000\u0000\u035b\u035a\u0001\u0000\u0000\u0000\u035c"+
		"\u000f\u0001\u0000\u0000\u0000\u035d\u036d\u0003\u0152\u00a9\u0000\u035e"+
		"\u036d\u0003\u0154\u00aa\u0000\u035f\u036d\u0003\u0156\u00ab\u0000\u0360"+
		"\u036d\u0003\u0158\u00ac\u0000\u0361\u036d\u0003\u015a\u00ad\u0000\u0362"+
		"\u036d\u0003\u015c\u00ae\u0000\u0363\u036d\u0003\u015e\u00af\u0000\u0364"+
		"\u036d\u0003\u0160\u00b0\u0000\u0365\u036d\u0003\u0162\u00b1\u0000\u0366"+
		"\u036d\u0003\u017a\u00bd\u0000\u0367\u036d\u0003\u017c\u00be\u0000\u0368"+
		"\u036d\u0003\u017e\u00bf\u0000\u0369\u036d\u0003\u0180\u00c0\u0000\u036a"+
		"\u036d\u0003\u0182\u00c1\u0000\u036b\u036d\u0003\u0184\u00c2\u0000\u036c"+
		"\u035d\u0001\u0000\u0000\u0000\u036c\u035e\u0001\u0000\u0000\u0000\u036c"+
		"\u035f\u0001\u0000\u0000\u0000\u036c\u0360\u0001\u0000\u0000\u0000\u036c"+
		"\u0361\u0001\u0000\u0000\u0000\u036c\u0362\u0001\u0000\u0000\u0000\u036c"+
		"\u0363\u0001\u0000\u0000\u0000\u036c\u0364\u0001\u0000\u0000\u0000\u036c"+
		"\u0365\u0001\u0000\u0000\u0000\u036c\u0366\u0001\u0000\u0000\u0000\u036c"+
		"\u0367\u0001\u0000\u0000\u0000\u036c\u0368\u0001\u0000\u0000\u0000\u036c"+
		"\u0369\u0001\u0000\u0000\u0000\u036c\u036a\u0001\u0000\u0000\u0000\u036c"+
		"\u036b\u0001\u0000\u0000\u0000\u036d\u0011\u0001\u0000\u0000\u0000\u036e"+
		"\u0372\u0003\u0186\u00c3\u0000\u036f\u0372\u0003\u0188\u00c4\u0000\u0370"+
		"\u0372\u0003\u018a\u00c5\u0000\u0371\u036e\u0001\u0000\u0000\u0000\u0371"+
		"\u036f\u0001\u0000\u0000\u0000\u0371\u0370\u0001\u0000\u0000\u0000\u0372"+
		"\u0013\u0001\u0000\u0000\u0000\u0373\u0381\u0003\u018e\u00c7\u0000\u0374"+
		"\u0381\u0003\u0190\u00c8\u0000\u0375\u0381\u0003\u0192\u00c9\u0000\u0376"+
		"\u0381\u0003\u0196\u00cb\u0000\u0377\u0381\u0003\u0198\u00cc\u0000\u0378"+
		"\u0381\u0003\u019a\u00cd\u0000\u0379\u0381\u0003\u019e\u00cf\u0000\u037a";
	private static final String _serializedATNSegment1 =
		"\u0381\u0003\u0194\u00ca\u0000\u037b\u0381\u0003\u019c\u00ce\u0000\u037c"+
		"\u0381\u0003\u01a0\u00d0\u0000\u037d\u037e\u00032\u0019\u0000\u037e\u037f"+
		"\u0003\f\u0006\u0000\u037f\u0381\u0001\u0000\u0000\u0000\u0380\u0373\u0001"+
		"\u0000\u0000\u0000\u0380\u0374\u0001\u0000\u0000\u0000\u0380\u0375\u0001"+
		"\u0000\u0000\u0000\u0380\u0376\u0001\u0000\u0000\u0000\u0380\u0377\u0001"+
		"\u0000\u0000\u0000\u0380\u0378\u0001\u0000\u0000\u0000\u0380\u0379\u0001"+
		"\u0000\u0000\u0000\u0380\u037a\u0001\u0000\u0000\u0000\u0380\u037b\u0001"+
		"\u0000\u0000\u0000\u0380\u037c\u0001\u0000\u0000\u0000\u0380\u037d\u0001"+
		"\u0000\u0000\u0000\u0381\u0015\u0001\u0000\u0000\u0000\u0382\u039d\u0003"+
		"\u01b2\u00d9\u0000\u0383\u039d\u0003\u01b4\u00da\u0000\u0384\u039d\u0003"+
		"\u01b6\u00db\u0000\u0385\u039d\u0003\u01b8\u00dc\u0000\u0386\u039d\u0003"+
		"\u01bc\u00de\u0000\u0387\u039d\u0003\u01be\u00df\u0000\u0388\u039d\u0003"+
		"\u01c0\u00e0\u0000\u0389\u039d\u0003\u01c2\u00e1\u0000\u038a\u039d\u0003"+
		"\u01dc\u00ee\u0000\u038b\u039d\u0003\u01de\u00ef\u0000\u038c\u039d\u0003"+
		"\u01e0\u00f0\u0000\u038d\u039d\u0003\u01e2\u00f1\u0000\u038e\u039d\u0003"+
		"\u01e4\u00f2\u0000\u038f\u039d\u0003\u01e8\u00f4\u0000\u0390\u039d\u0003"+
		"\u01ea\u00f5\u0000\u0391\u039d\u0003\u01ec\u00f6\u0000\u0392\u039d\u0003"+
		"\u01ee\u00f7\u0000\u0393\u039d\u0003\u01f0\u00f8\u0000\u0394\u039d\u0003"+
		"\u0200\u0100\u0000\u0395\u039d\u0003\u0202\u0101\u0000\u0396\u039d\u0003"+
		"\u0204\u0102\u0000\u0397\u039d\u0003\u0206\u0103\u0000\u0398\u039d\u0003"+
		"\u0208\u0104\u0000\u0399\u039d\u0003\u020a\u0105\u0000\u039a\u039d\u0003"+
		"\u020c\u0106\u0000\u039b\u039d\u0003\u01f2\u00f9\u0000\u039c\u0382\u0001"+
		"\u0000\u0000\u0000\u039c\u0383\u0001\u0000\u0000\u0000\u039c\u0384\u0001"+
		"\u0000\u0000\u0000\u039c\u0385\u0001\u0000\u0000\u0000\u039c\u0386\u0001"+
		"\u0000\u0000\u0000\u039c\u0387\u0001\u0000\u0000\u0000\u039c\u0388\u0001"+
		"\u0000\u0000\u0000\u039c\u0389\u0001\u0000\u0000\u0000\u039c\u038a\u0001"+
		"\u0000\u0000\u0000\u039c\u038b\u0001\u0000\u0000\u0000\u039c\u038c\u0001"+
		"\u0000\u0000\u0000\u039c\u038d\u0001\u0000\u0000\u0000\u039c\u038e\u0001"+
		"\u0000\u0000\u0000\u039c\u038f\u0001\u0000\u0000\u0000\u039c\u0390\u0001"+
		"\u0000\u0000\u0000\u039c\u0391\u0001\u0000\u0000\u0000\u039c\u0392\u0001"+
		"\u0000\u0000\u0000\u039c\u0393\u0001\u0000\u0000\u0000\u039c\u0394\u0001"+
		"\u0000\u0000\u0000\u039c\u0395\u0001\u0000\u0000\u0000\u039c\u0396\u0001"+
		"\u0000\u0000\u0000\u039c\u0397\u0001\u0000\u0000\u0000\u039c\u0398\u0001"+
		"\u0000\u0000\u0000\u039c\u0399\u0001\u0000\u0000\u0000\u039c\u039a\u0001"+
		"\u0000\u0000\u0000\u039c\u039b\u0001\u0000\u0000\u0000\u039d\u0017\u0001"+
		"\u0000\u0000\u0000\u039e\u03a6\u0003\u0216\u010b\u0000\u039f\u03a6\u0003"+
		"\u0218\u010c\u0000\u03a0\u03a6\u0003\u021c\u010e\u0000\u03a1\u03a6\u0003"+
		"\u021e\u010f\u0000\u03a2\u03a6\u0003\u0220\u0110\u0000\u03a3\u03a6\u0003"+
		"\u0222\u0111\u0000\u03a4\u03a6\u0003\u0226\u0113\u0000\u03a5\u039e\u0001"+
		"\u0000\u0000\u0000\u03a5\u039f\u0001\u0000\u0000\u0000\u03a5\u03a0\u0001"+
		"\u0000\u0000\u0000\u03a5\u03a1\u0001\u0000\u0000\u0000\u03a5\u03a2\u0001"+
		"\u0000\u0000\u0000\u03a5\u03a3\u0001\u0000\u0000\u0000\u03a5\u03a4\u0001"+
		"\u0000\u0000\u0000\u03a6\u0019\u0001\u0000\u0000\u0000\u03a7\u03a8\u0005"+
		"\"\u0000\u0000\u03a8\u03aa\u0007\u0000\u0000\u0000\u03a9\u03ab\u0003\u028a"+
		"\u0145\u0000\u03aa\u03a9\u0001\u0000\u0000\u0000\u03aa\u03ab\u0001\u0000"+
		"\u0000\u0000\u03ab\u03ac\u0001\u0000\u0000\u0000\u03ac\u03b0\u0003\u0250"+
		"\u0128\u0000\u03ad\u03af\u0003@ \u0000\u03ae\u03ad\u0001\u0000\u0000\u0000"+
		"\u03af\u03b2\u0001\u0000\u0000\u0000\u03b0\u03ae\u0001\u0000\u0000\u0000"+
		"\u03b0\u03b1\u0001\u0000\u0000\u0000\u03b1\u001b\u0001\u0000\u0000\u0000"+
		"\u03b2\u03b0\u0001\u0000\u0000\u0000\u03b3\u03b5\u0005\"\u0000\u0000\u03b4"+
		"\u03b6\u0003F#\u0000\u03b5\u03b4\u0001\u0000\u0000\u0000\u03b5\u03b6\u0001"+
		"\u0000\u0000\u0000\u03b6\u03b7\u0001\u0000\u0000\u0000\u03b7\u03b9\u0005"+
		"\u019f\u0000\u0000\u03b8\u03ba\u0003\u028a\u0145\u0000\u03b9\u03b8\u0001"+
		"\u0000\u0000\u0000\u03b9\u03ba\u0001\u0000\u0000\u0000\u03ba\u03bb\u0001"+
		"\u0000\u0000\u0000\u03bb\u03bc\u0003\u022c\u0116\u0000\u03bc\u03bd\u0005"+
		"v\u0000\u0000\u03bd\u03be\u0005\u025f\u0000\u0000\u03be\u03c5\u0003H$"+
		"\u0000\u03bf\u03c0\u0005v\u0000\u0000\u03c0\u03c2\u0005\u0173\u0000\u0000"+
		"\u03c1\u03c3\u0005r\u0000\u0000\u03c2\u03c1\u0001\u0000\u0000\u0000\u03c2"+
		"\u03c3\u0001\u0000\u0000\u0000\u03c3\u03c4\u0001\u0000\u0000\u0000\u03c4"+
		"\u03c6\u0005\u0232\u0000\u0000\u03c5\u03bf\u0001\u0000\u0000\u0000\u03c5"+
		"\u03c6\u0001\u0000\u0000\u0000\u03c6\u03c8\u0001\u0000\u0000\u0000\u03c7"+
		"\u03c9\u0003P(\u0000\u03c8\u03c7\u0001\u0000\u0000\u0000\u03c8\u03c9\u0001"+
		"\u0000\u0000\u0000\u03c9\u03cc\u0001\u0000\u0000\u0000\u03ca\u03cb\u0005"+
		"\u0170\u0000\u0000\u03cb\u03cd\u0005\u0491\u0000\u0000\u03cc\u03ca\u0001"+
		"\u0000\u0000\u0000\u03cc\u03cd\u0001\u0000\u0000\u0000\u03cd\u03ce\u0001"+
		"\u0000\u0000\u0000\u03ce\u03cf\u0005\u018f\u0000\u0000\u03cf\u03d0\u0003"+
		"\u018c\u00c6\u0000\u03d0\u001d\u0001\u0000\u0000\u0000\u03d1\u03d3\u0005"+
		"\"\u0000\u0000\u03d2\u03d4\u0003\u028c\u0146\u0000\u03d3\u03d2\u0001\u0000"+
		"\u0000\u0000\u03d3\u03d4\u0001\u0000\u0000\u0000\u03d4\u03d6\u0001\u0000"+
		"\u0000\u0000\u03d5\u03d7\u0007\u0001\u0000\u0000\u03d6\u03d5\u0001\u0000"+
		"\u0000\u0000\u03d6\u03d7\u0001\u0000\u0000\u0000\u03d7\u03d9\u0001\u0000"+
		"\u0000\u0000\u03d8\u03da\u0007\u0002\u0000\u0000\u03d9\u03d8\u0001\u0000"+
		"\u0000\u0000\u03d9\u03da\u0001\u0000\u0000\u0000\u03da\u03db\u0001\u0000"+
		"\u0000\u0000\u03db\u03dd\u0005Q\u0000\u0000\u03dc\u03de\u0003\u028a\u0145"+
		"\u0000\u03dd\u03dc\u0001\u0000\u0000\u0000\u03dd\u03de\u0001\u0000\u0000"+
		"\u0000\u03de\u03df\u0001\u0000\u0000\u0000\u03df\u03e1\u0003\u0250\u0128"+
		"\u0000\u03e0\u03e2\u0003R)\u0000\u03e1\u03e0\u0001\u0000\u0000\u0000\u03e1"+
		"\u03e2\u0001\u0000\u0000\u0000\u03e2\u03e3\u0001\u0000\u0000\u0000\u03e3"+
		"\u03e4\u0005v\u0000\u0000\u03e4\u03e5\u0003\u022e\u0117\u0000\u03e5\u03e7"+
		"\u0003\u0276\u013b\u0000\u03e6\u03e8\u0003\u028e\u0147\u0000\u03e7\u03e6"+
		"\u0001\u0000\u0000\u0000\u03e7\u03e8\u0001\u0000\u0000\u0000\u03e8\u03ec"+
		"\u0001\u0000\u0000\u0000\u03e9\u03eb\u0003T*\u0000\u03ea\u03e9\u0001\u0000"+
		"\u0000\u0000\u03eb\u03ee\u0001\u0000\u0000\u0000\u03ec\u03ea\u0001\u0000"+
		"\u0000\u0000\u03ec\u03ed\u0001\u0000\u0000\u0000\u03ed\u03fb\u0001\u0000"+
		"\u0000\u0000\u03ee\u03ec\u0001\u0000\u0000\u0000\u03ef\u03f1\u0005\u0150"+
		"\u0000\u0000\u03f0\u03f2\u0005\u0479\u0000\u0000\u03f1\u03f0\u0001\u0000"+
		"\u0000\u0000\u03f1\u03f2\u0001\u0000\u0000\u0000\u03f2\u03f3\u0001\u0000"+
		"\u0000\u0000\u03f3\u03fa\u0007\u0003\u0000\u0000\u03f4\u03f6\u0005g\u0000"+
		"\u0000\u03f5\u03f7\u0005\u0479\u0000\u0000\u03f6\u03f5\u0001\u0000\u0000"+
		"\u0000\u03f6\u03f7\u0001\u0000\u0000\u0000\u03f7\u03f8\u0001\u0000\u0000"+
		"\u0000\u03f8\u03fa\u0007\u0004\u0000\u0000\u03f9\u03ef\u0001\u0000\u0000"+
		"\u0000\u03f9\u03f4\u0001\u0000\u0000\u0000\u03fa\u03fd\u0001\u0000\u0000"+
		"\u0000\u03fb\u03f9\u0001\u0000\u0000\u0000\u03fb\u03fc\u0001\u0000\u0000"+
		"\u0000\u03fc\u001f\u0001\u0000\u0000\u0000\u03fd\u03fb\u0001\u0000\u0000"+
		"\u0000\u03fe\u03ff\u0005\"\u0000\u0000\u03ff\u0400\u0005\u01dc\u0000\u0000"+
		"\u0400\u0401\u0005I\u0000\u0000\u0401\u0402\u0003\u0250\u0128\u0000\u0402"+
		"\u0403\u0005\u0005\u0000\u0000\u0403\u0404\u0005\u0297\u0000\u0000\u0404"+
		"\u040a\u0005\u0491\u0000\u0000\u0405\u0407\u0005\u01c5\u0000\u0000\u0406"+
		"\u0408\u0005\u0479\u0000\u0000\u0407\u0406\u0001\u0000\u0000\u0000\u0407"+
		"\u0408\u0001\u0000\u0000\u0000\u0408\u0409\u0001\u0000\u0000\u0000\u0409"+
		"\u040b\u0003\u0258\u012c\u0000\u040a\u0405\u0001\u0000\u0000\u0000\u040a"+
		"\u040b\u0001\u0000\u0000\u0000\u040b\u0411\u0001\u0000\u0000\u0000\u040c"+
		"\u040e\u0005\u0298\u0000\u0000\u040d\u040f\u0005\u0479\u0000\u0000\u040e"+
		"\u040d\u0001\u0000\u0000\u0000\u040e\u040f\u0001\u0000\u0000\u0000\u040f"+
		"\u0410\u0001\u0000\u0000\u0000\u0410\u0412\u0003\u0258\u012c\u0000\u0411"+
		"\u040c\u0001\u0000\u0000\u0000\u0411\u0412\u0001\u0000\u0000\u0000\u0412"+
		"\u0418\u0001\u0000\u0000\u0000\u0413\u0415\u0005\u023e\u0000\u0000\u0414"+
		"\u0416\u0005\u0479\u0000\u0000\u0415\u0414\u0001\u0000\u0000\u0000\u0415"+
		"\u0416\u0001\u0000\u0000\u0000\u0416\u0417\u0001\u0000\u0000\u0000\u0417"+
		"\u0419\u0003\u0258\u012c\u0000\u0418\u0413\u0001\u0000\u0000\u0000\u0418"+
		"\u0419\u0001\u0000\u0000\u0000\u0419\u041f\u0001\u0000\u0000\u0000\u041a"+
		"\u041c\u0005\u0211\u0000\u0000\u041b\u041d\u0005\u0479\u0000\u0000\u041c"+
		"\u041b\u0001\u0000\u0000\u0000\u041c\u041d\u0001\u0000\u0000\u0000\u041d"+
		"\u041e\u0001\u0000\u0000\u0000\u041e\u0420\u0003\u0250\u0128\u0000\u041f"+
		"\u041a\u0001\u0000\u0000\u0000\u041f\u0420\u0001\u0000\u0000\u0000\u0420"+
		"\u0422\u0001\u0000\u0000\u0000\u0421\u0423\u0005\u02a6\u0000\u0000\u0422"+
		"\u0421\u0001\u0000\u0000\u0000\u0422\u0423\u0001\u0000\u0000\u0000\u0423"+
		"\u0429\u0001\u0000\u0000\u0000\u0424\u0426\u0005\u0170\u0000\u0000\u0425"+
		"\u0427\u0005\u0479\u0000\u0000\u0426\u0425\u0001\u0000\u0000\u0000\u0426"+
		"\u0427\u0001\u0000\u0000\u0000\u0427\u0428\u0001\u0000\u0000\u0000\u0428"+
		"\u042a\u0005\u0491\u0000\u0000\u0429\u0424\u0001\u0000\u0000\u0000\u0429"+
		"\u042a\u0001\u0000\u0000\u0000\u042a\u042b\u0001\u0000\u0000\u0000\u042b"+
		"\u042d\u0005\u0199\u0000\u0000\u042c\u042e\u0005\u0479\u0000\u0000\u042d"+
		"\u042c\u0001\u0000\u0000\u0000\u042d\u042e\u0001\u0000\u0000\u0000\u042e"+
		"\u042f\u0001\u0000\u0000\u0000\u042f\u0430\u0003\u0242\u0121\u0000\u0430"+
		"!\u0001\u0000\u0000\u0000\u0431\u0433\u0005\"\u0000\u0000\u0432\u0434"+
		"\u0003\u028c\u0146\u0000\u0433\u0432\u0001\u0000\u0000\u0000\u0433\u0434"+
		"\u0001\u0000\u0000\u0000\u0434\u0436\u0001\u0000\u0000\u0000\u0435\u0437"+
		"\u0003F#\u0000\u0436\u0435\u0001\u0000\u0000\u0000\u0436\u0437\u0001\u0000"+
		"\u0000\u0000\u0437\u0438\u0001\u0000\u0000\u0000\u0438\u0439\u0005\u0084"+
		"\u0000\u0000\u0439\u043a\u0003\u022c\u0116\u0000\u043a\u043c\u0005\u0482"+
		"\u0000\u0000\u043b\u043d\u0003V+\u0000\u043c\u043b\u0001\u0000\u0000\u0000"+
		"\u043c\u043d\u0001\u0000\u0000\u0000\u043d\u0442\u0001\u0000\u0000\u0000"+
		"\u043e\u043f\u0005\u0484\u0000\u0000\u043f\u0441\u0003V+\u0000\u0440\u043e"+
		"\u0001\u0000\u0000\u0000\u0441\u0444\u0001\u0000\u0000\u0000\u0442\u0440"+
		"\u0001\u0000\u0000\u0000\u0442\u0443\u0001\u0000\u0000\u0000\u0443\u0445"+
		"\u0001\u0000\u0000\u0000\u0444\u0442\u0001\u0000\u0000\u0000\u0445\u0449"+
		"\u0005\u0483\u0000\u0000\u0446\u0448\u0003Z-\u0000\u0447\u0446\u0001\u0000"+
		"\u0000\u0000\u0448\u044b\u0001\u0000\u0000\u0000\u0449\u0447\u0001\u0000"+
		"\u0000\u0000\u0449\u044a\u0001\u0000\u0000\u0000\u044a\u044c\u0001\u0000"+
		"\u0000\u0000\u044b\u0449\u0001\u0000\u0000\u0000\u044c\u044d\u0003\u018c"+
		"\u00c6\u0000\u044d#\u0001\u0000\u0000\u0000\u044e\u0450\u0005\"\u0000"+
		"\u0000\u044f\u0451\u0003\u028c\u0146\u0000\u0450\u044f\u0001\u0000\u0000"+
		"\u0000\u0450\u0451\u0001\u0000\u0000\u0000\u0451\u0453\u0001\u0000\u0000"+
		"\u0000\u0452\u0454\u0003F#\u0000\u0453\u0452\u0001\u0000\u0000\u0000\u0453"+
		"\u0454\u0001\u0000\u0000\u0000\u0454\u0456\u0001\u0000\u0000\u0000\u0455"+
		"\u0457\u0005\u014f\u0000\u0000\u0456\u0455\u0001\u0000\u0000\u0000\u0456"+
		"\u0457\u0001\u0000\u0000\u0000\u0457\u0458\u0001\u0000\u0000\u0000\u0458"+
		"\u045a\u0005\u01b5\u0000\u0000\u0459\u045b\u0003\u028a\u0145\u0000\u045a"+
		"\u0459\u0001\u0000\u0000\u0000\u045a\u045b\u0001\u0000\u0000\u0000\u045b"+
		"\u045c\u0001\u0000\u0000\u0000\u045c\u045d\u0003\u022c\u0116\u0000\u045d"+
		"\u045f\u0005\u0482\u0000\u0000\u045e\u0460\u0003X,\u0000\u045f\u045e\u0001"+
		"\u0000\u0000\u0000\u045f\u0460\u0001\u0000\u0000\u0000\u0460\u0465\u0001"+
		"\u0000\u0000\u0000\u0461\u0462\u0005\u0484\u0000\u0000\u0462\u0464\u0003"+
		"X,\u0000\u0463\u0461\u0001\u0000\u0000\u0000\u0464\u0467\u0001\u0000\u0000"+
		"\u0000\u0465\u0463\u0001\u0000\u0000\u0000\u0465\u0466\u0001\u0000\u0000"+
		"\u0000\u0466\u0468\u0001\u0000\u0000\u0000\u0467\u0465\u0001\u0000\u0000"+
		"\u0000\u0468\u0469\u0005\u0483\u0000\u0000\u0469\u046a\u0005\u0254\u0000"+
		"\u0000\u046a\u046e\u0003\u0264\u0132\u0000\u046b\u046d\u0003Z-\u0000\u046c"+
		"\u046b\u0001\u0000\u0000\u0000\u046d\u0470\u0001\u0000\u0000\u0000\u046e"+
		"\u046c\u0001\u0000\u0000\u0000\u046e\u046f\u0001\u0000\u0000\u0000\u046f"+
		"\u0473\u0001\u0000\u0000\u0000\u0470\u046e\u0001\u0000\u0000\u0000\u0471"+
		"\u0474\u0003\u018c\u00c6\u0000\u0472\u0474\u0003\u019c\u00ce\u0000\u0473"+
		"\u0471\u0001\u0000\u0000\u0000\u0473\u0472\u0001\u0000\u0000\u0000\u0474"+
		"%\u0001\u0000\u0000\u0000\u0475\u0476\u0005\"\u0000\u0000\u0476\u0478"+
		"\u0005\u0256\u0000\u0000\u0477\u0479\u0003\u028a\u0145\u0000\u0478\u0477"+
		"\u0001\u0000\u0000\u0000\u0478\u0479\u0001\u0000\u0000\u0000\u0479\u047a"+
		"\u0001\u0000\u0000\u0000\u047a\u047f\u0003\u0230\u0118\u0000\u047b\u047c"+
		"\u0005\u0484\u0000\u0000\u047c\u047e\u0003\u0230\u0118\u0000\u047d\u047b"+
		"\u0001\u0000\u0000\u0000\u047e\u0481\u0001\u0000\u0000\u0000\u047f\u047d"+
		"\u0001\u0000\u0000\u0000\u047f\u0480\u0001\u0000\u0000\u0000\u0480\'\u0001"+
		"\u0000\u0000\u0000\u0481\u047f\u0001\u0000\u0000\u0000\u0482\u0483\u0005"+
		"\"\u0000\u0000\u0483\u0484\u0005\u0262\u0000\u0000\u0484\u0485\u0003\u0250"+
		"\u0128\u0000\u0485\u0486\u0005C\u0000\u0000\u0486\u0487\u0005\u0184\u0000"+
		"\u0000\u0487\u0488\u0005\u02ab\u0000\u0000\u0488\u0489\u0007\u0005\u0000"+
		"\u0000\u0489\u048a\u0005\u021e\u0000\u0000\u048a\u048b\u0005\u0482\u0000"+
		"\u0000\u048b\u0490\u0003\\.\u0000\u048c\u048d\u0005\u0484\u0000\u0000"+
		"\u048d\u048f\u0003\\.\u0000\u048e\u048c\u0001\u0000\u0000\u0000\u048f"+
		"\u0492\u0001\u0000\u0000\u0000\u0490\u048e\u0001\u0000\u0000\u0000\u0490"+
		"\u0491\u0001\u0000\u0000\u0000\u0491\u0493\u0001\u0000\u0000\u0000\u0492"+
		"\u0490\u0001\u0000\u0000\u0000\u0493\u0494\u0005\u0483\u0000\u0000\u0494"+
		")\u0001\u0000\u0000\u0000\u0495\u0497\u0005\"\u0000\u0000\u0496\u0498"+
		"\u0003\u028c\u0146\u0000\u0497\u0496\u0001\u0000\u0000\u0000\u0497\u0498"+
		"\u0001\u0000\u0000\u0000\u0498\u049a\u0001\u0000\u0000\u0000\u0499\u049b"+
		"\u0005\u028c\u0000\u0000\u049a\u0499\u0001\u0000\u0000\u0000\u049a\u049b"+
		"\u0001\u0000\u0000\u0000\u049b\u049c\u0001\u0000\u0000\u0000\u049c\u049e"+
		"\u0005\u00ac\u0000\u0000\u049d\u049f\u0003\u028a\u0145\u0000\u049e\u049d"+
		"\u0001\u0000\u0000\u0000\u049e\u049f\u0001\u0000\u0000\u0000\u049f\u04a0"+
		"\u0001\u0000\u0000\u0000\u04a0\u04a8\u0003\u022e\u0117\u0000\u04a1\u04a2"+
		"\u0005b\u0000\u0000\u04a2\u04a9\u0003\u022e\u0117\u0000\u04a3\u04a4\u0005"+
		"\u0482\u0000\u0000\u04a4\u04a5\u0005b\u0000\u0000\u04a5\u04a6\u0003\u022e"+
		"\u0117\u0000\u04a6\u04a7\u0005\u0483\u0000\u0000\u04a7\u04a9\u0001\u0000"+
		"\u0000\u0000\u04a8\u04a1\u0001\u0000\u0000\u0000\u04a8\u04a3\u0001\u0000"+
		"\u0000\u0000\u04a9\u04ed\u0001\u0000\u0000\u0000\u04aa\u04ac\u0005\"\u0000"+
		"\u0000\u04ab\u04ad\u0003\u028c\u0146\u0000\u04ac\u04ab\u0001\u0000\u0000"+
		"\u0000\u04ac\u04ad\u0001\u0000\u0000\u0000\u04ad\u04af\u0001\u0000\u0000"+
		"\u0000\u04ae\u04b0\u0005\u028c\u0000\u0000\u04af\u04ae\u0001\u0000\u0000"+
		"\u0000\u04af\u04b0\u0001\u0000\u0000\u0000\u04b0\u04b1\u0001\u0000\u0000"+
		"\u0000\u04b1\u04b3\u0005\u00ac\u0000\u0000\u04b2\u04b4\u0003\u028a\u0145"+
		"\u0000\u04b3\u04b2\u0001\u0000\u0000\u0000\u04b3\u04b4\u0001\u0000\u0000"+
		"\u0000\u04b4\u04b5\u0001\u0000\u0000\u0000\u04b5\u04b7\u0003\u022e\u0117"+
		"\u0000\u04b6\u04b8\u0003^/\u0000\u04b7\u04b6\u0001\u0000\u0000\u0000\u04b7"+
		"\u04b8\u0001\u0000\u0000\u0000\u04b8\u04c3\u0001\u0000\u0000\u0000\u04b9"+
		"\u04c0\u0003p8\u0000\u04ba\u04bc\u0005\u0484\u0000\u0000\u04bb\u04ba\u0001"+
		"\u0000\u0000\u0000\u04bb\u04bc\u0001\u0000\u0000\u0000\u04bc\u04bd\u0001"+
		"\u0000\u0000\u0000\u04bd\u04bf\u0003p8\u0000\u04be\u04bb\u0001\u0000\u0000"+
		"\u0000\u04bf\u04c2\u0001\u0000\u0000\u0000\u04c0\u04be\u0001\u0000\u0000"+
		"\u0000\u04c0\u04c1\u0001\u0000\u0000\u0000\u04c1\u04c4\u0001\u0000\u0000"+
		"\u0000\u04c2\u04c0\u0001\u0000\u0000\u0000\u04c3\u04b9\u0001\u0000\u0000"+
		"\u0000\u04c3\u04c4\u0001\u0000\u0000\u0000\u04c4\u04c6\u0001\u0000\u0000"+
		"\u0000\u04c5\u04c7\u0003v;\u0000\u04c6\u04c5\u0001\u0000\u0000\u0000\u04c6"+
		"\u04c7\u0001\u0000\u0000\u0000\u04c7\u04c9\u0001\u0000\u0000\u0000\u04c8"+
		"\u04ca\u0007\u0006\u0000\u0000\u04c9\u04c8\u0001\u0000\u0000\u0000\u04c9"+
		"\u04ca\u0001\u0000\u0000\u0000\u04ca\u04cc\u0001\u0000\u0000\u0000\u04cb"+
		"\u04cd\u0005\f\u0000\u0000\u04cc\u04cb\u0001\u0000\u0000\u0000\u04cc\u04cd"+
		"\u0001\u0000\u0000\u0000\u04cd\u04ce\u0001\u0000\u0000\u0000\u04ce\u04cf"+
		"\u0003\u00d2i\u0000\u04cf\u04ed\u0001\u0000\u0000\u0000\u04d0\u04d2\u0005"+
		"\"\u0000\u0000\u04d1\u04d3\u0003\u028c\u0146\u0000\u04d2\u04d1\u0001\u0000"+
		"\u0000\u0000\u04d2\u04d3\u0001\u0000\u0000\u0000\u04d3\u04d5\u0001\u0000"+
		"\u0000\u0000\u04d4\u04d6\u0005\u028c\u0000\u0000\u04d5\u04d4\u0001\u0000"+
		"\u0000\u0000\u04d5\u04d6\u0001\u0000\u0000\u0000\u04d6\u04d7\u0001\u0000"+
		"\u0000\u0000\u04d7\u04d9\u0005\u00ac\u0000\u0000\u04d8\u04da\u0003\u028a"+
		"\u0145\u0000\u04d9\u04d8\u0001\u0000\u0000\u0000\u04d9\u04da\u0001\u0000"+
		"\u0000\u0000\u04da\u04db\u0001\u0000\u0000\u0000\u04db\u04dc\u0003\u022e"+
		"\u0117\u0000\u04dc\u04e7\u0003^/\u0000\u04dd\u04e4\u0003p8\u0000\u04de"+
		"\u04e0\u0005\u0484\u0000\u0000\u04df\u04de\u0001\u0000\u0000\u0000\u04df"+
		"\u04e0\u0001\u0000\u0000\u0000\u04e0\u04e1\u0001\u0000\u0000\u0000\u04e1"+
		"\u04e3\u0003p8\u0000\u04e2\u04df\u0001\u0000\u0000\u0000\u04e3\u04e6\u0001"+
		"\u0000\u0000\u0000\u04e4\u04e2\u0001\u0000\u0000\u0000\u04e4\u04e5\u0001"+
		"\u0000\u0000\u0000\u04e5\u04e8\u0001\u0000\u0000\u0000\u04e6\u04e4\u0001"+
		"\u0000\u0000\u0000\u04e7\u04dd\u0001\u0000\u0000\u0000\u04e7\u04e8\u0001"+
		"\u0000\u0000\u0000\u04e8\u04ea\u0001\u0000\u0000\u0000\u04e9\u04eb\u0003"+
		"v;\u0000\u04ea\u04e9\u0001\u0000\u0000\u0000\u04ea\u04eb\u0001\u0000\u0000"+
		"\u0000\u04eb\u04ed\u0001\u0000\u0000\u0000\u04ec\u0495\u0001\u0000\u0000"+
		"\u0000\u04ec\u04aa\u0001\u0000\u0000\u0000\u04ec\u04d0\u0001\u0000\u0000"+
		"\u0000\u04ed+\u0001\u0000\u0000\u0000\u04ee\u04ef\u0005\"\u0000\u0000"+
		"\u04ef\u04f0\u0005\u028a\u0000\u0000\u04f0\u04f1\u0003\u0250\u0128\u0000"+
		"\u04f1\u04f2\u0005\u0005\u0000\u0000\u04f2\u04f3\u0005\u0185\u0000\u0000"+
		"\u04f3\u04f7\u0005\u0491\u0000\u0000\u04f4\u04f5\u0005\u01ac\u0000\u0000"+
		"\u04f5\u04f6\u0005\u0479\u0000\u0000\u04f6\u04f8\u0003\u0258\u012c\u0000"+
		"\u04f7\u04f4\u0001\u0000\u0000\u0000\u04f7\u04f8\u0001\u0000\u0000\u0000"+
		"\u04f8\u04fe\u0001\u0000\u0000\u0000\u04f9\u04fb\u0005\u0199\u0000\u0000"+
		"\u04fa\u04fc\u0005\u0479\u0000\u0000\u04fb\u04fa\u0001\u0000\u0000\u0000"+
		"\u04fb\u04fc\u0001\u0000\u0000\u0000\u04fc\u04fd\u0001\u0000\u0000\u0000"+
		"\u04fd\u04ff\u0003\u0242\u0121\u0000\u04fe\u04f9\u0001\u0000\u0000\u0000"+
		"\u04fe\u04ff\u0001\u0000\u0000\u0000\u04ff-\u0001\u0000\u0000\u0000\u0500"+
		"\u0501\u0005\"\u0000\u0000\u0501\u0502\u0005\u028a\u0000\u0000\u0502\u0503"+
		"\u0003\u0250\u0128\u0000\u0503\u0504\u0005\u0005\u0000\u0000\u0504\u0505"+
		"\u0005\u0185\u0000\u0000\u0505\u0506\u0005\u0491\u0000\u0000\u0506\u0507"+
		"\u0005\u00ba\u0000\u0000\u0507\u0508\u0005\u01dc\u0000\u0000\u0508\u0509"+
		"\u0005I\u0000\u0000\u0509\u050f\u0003\u0250\u0128\u0000\u050a\u050c\u0005"+
		"\u01a7\u0000\u0000\u050b\u050d\u0005\u0479\u0000\u0000\u050c\u050b\u0001"+
		"\u0000\u0000\u0000\u050c\u050d\u0001\u0000\u0000\u0000\u050d\u050e\u0001"+
		"\u0000\u0000\u0000\u050e\u0510\u0003\u0258\u012c\u0000\u050f\u050a\u0001"+
		"\u0000\u0000\u0000\u050f\u0510\u0001\u0000\u0000\u0000\u0510\u0516\u0001"+
		"\u0000\u0000\u0000\u0511\u0513\u0005\u01c5\u0000\u0000\u0512\u0514\u0005"+
		"\u0479\u0000\u0000\u0513\u0512\u0001\u0000\u0000\u0000\u0513\u0514\u0001"+
		"\u0000\u0000\u0000\u0514\u0515\u0001\u0000\u0000\u0000\u0515\u0517\u0003"+
		"\u0258\u012c\u0000\u0516\u0511\u0001\u0000\u0000\u0000\u0516\u0517\u0001"+
		"\u0000\u0000\u0000\u0517\u051d\u0001\u0000\u0000\u0000\u0518\u051a\u0005"+
		"\u0155\u0000\u0000\u0519\u051b\u0005\u0479\u0000\u0000\u051a\u0519\u0001"+
		"\u0000\u0000\u0000\u051a\u051b\u0001\u0000\u0000\u0000\u051b\u051c\u0001"+
		"\u0000\u0000\u0000\u051c\u051e\u0003\u0258\u012c\u0000\u051d\u0518\u0001"+
		"\u0000\u0000\u0000\u051d\u051e\u0001\u0000\u0000\u0000\u051e\u0524\u0001"+
		"\u0000\u0000\u0000\u051f\u0521\u0005\u01f6\u0000\u0000\u0520\u0522\u0005"+
		"\u0479\u0000\u0000\u0521\u0520\u0001\u0000\u0000\u0000\u0521\u0522\u0001"+
		"\u0000\u0000\u0000\u0522\u0523\u0001\u0000\u0000\u0000\u0523\u0525\u0003"+
		"\u0258\u012c\u0000\u0524\u051f\u0001\u0000\u0000\u0000\u0524\u0525\u0001"+
		"\u0000\u0000\u0000\u0525\u052b\u0001\u0000\u0000\u0000\u0526\u0528\u0005"+
		"\u0211\u0000\u0000\u0527\u0529\u0005\u0479\u0000\u0000\u0528\u0527\u0001"+
		"\u0000\u0000\u0000\u0528\u0529\u0001\u0000\u0000\u0000\u0529\u052a\u0001"+
		"\u0000\u0000\u0000\u052a\u052c\u0003\u0250\u0128\u0000\u052b\u0526\u0001"+
		"\u0000\u0000\u0000\u052b\u052c\u0001\u0000\u0000\u0000\u052c\u052e\u0001"+
		"\u0000\u0000\u0000\u052d\u052f\u0005\u02a6\u0000\u0000\u052e\u052d\u0001"+
		"\u0000\u0000\u0000\u052e\u052f\u0001\u0000\u0000\u0000\u052f\u0535\u0001"+
		"\u0000\u0000\u0000\u0530\u0532\u0005\u0170\u0000\u0000\u0531\u0533\u0005"+
		"\u0479\u0000\u0000\u0532\u0531\u0001\u0000\u0000\u0000\u0532\u0533\u0001"+
		"\u0000\u0000\u0000\u0533\u0534\u0001\u0000\u0000\u0000\u0534\u0536\u0005"+
		"\u0491\u0000\u0000\u0535\u0530\u0001\u0000\u0000\u0000\u0535\u0536\u0001"+
		"\u0000\u0000\u0000\u0536\u0537\u0001\u0000\u0000\u0000\u0537\u0539\u0005"+
		"\u0199\u0000\u0000\u0538\u053a\u0005\u0479\u0000\u0000\u0539\u0538\u0001"+
		"\u0000\u0000\u0000\u0539\u053a\u0001\u0000\u0000\u0000\u053a\u053b\u0001"+
		"\u0000\u0000\u0000\u053b\u053c\u0003\u0242\u0121\u0000\u053c/\u0001\u0000"+
		"\u0000\u0000\u053d\u053f\u0005\"\u0000\u0000\u053e\u0540\u0003\u028c\u0146"+
		"\u0000\u053f\u053e\u0001\u0000\u0000\u0000\u053f\u0540\u0001\u0000\u0000"+
		"\u0000\u0540\u0542\u0001\u0000\u0000\u0000\u0541\u0543\u0003F#\u0000\u0542"+
		"\u0541\u0001\u0000\u0000\u0000\u0542\u0543\u0001\u0000\u0000\u0000\u0543"+
		"\u0544\u0001\u0000\u0000\u0000\u0544\u0545\u0005\u00b1\u0000\u0000\u0545"+
		"\u0546\u0003\u022c\u0116\u0000\u0546\u0547\u0007\u0007\u0000\u0000\u0547"+
		"\u0548\u0007\b\u0000\u0000\u0548\u0549\u0005v\u0000\u0000\u0549\u054a"+
		"\u0003\u022e\u0117\u0000\u054a\u054b\u0005A\u0000\u0000\u054b\u054c\u0005"+
		"5\u0000\u0000\u054c\u054f\u0005\u025a\u0000\u0000\u054d\u054e\u0007\t"+
		"\u0000\u0000\u054e\u0550\u0003\u022c\u0116\u0000\u054f\u054d\u0001\u0000"+
		"\u0000\u0000\u054f\u0550\u0001\u0000\u0000\u0000\u0550\u0551\u0001\u0000"+
		"\u0000\u0000\u0551\u0552\u0003\u018c\u00c6\u0000\u05521\u0001\u0000\u0000"+
		"\u0000\u0553\u0555\u0005\u00c0\u0000\u0000\u0554\u0556\u0005\u023d\u0000"+
		"\u0000\u0555\u0554\u0001\u0000\u0000\u0000\u0555\u0556\u0001\u0000\u0000"+
		"\u0000\u0556\u0557\u0001\u0000\u0000\u0000\u0557\u0558\u00034\u001a\u0000"+
		"\u05583\u0001\u0000\u0000\u0000\u0559\u0565\u00036\u001b\u0000\u055a\u055b"+
		"\u0005\u0482\u0000\u0000\u055b\u0560\u00038\u001c\u0000\u055c\u055d\u0005"+
		"\u0484\u0000\u0000\u055d\u055f\u00038\u001c\u0000\u055e\u055c\u0001\u0000"+
		"\u0000\u0000\u055f\u0562\u0001\u0000\u0000\u0000\u0560\u055e\u0001\u0000"+
		"\u0000\u0000\u0560\u0561\u0001\u0000\u0000\u0000\u0561\u0563\u0001\u0000"+
		"\u0000\u0000\u0562\u0560\u0001\u0000\u0000\u0000\u0563\u0564\u0005\u0483"+
		"\u0000\u0000\u0564\u0566\u0001\u0000\u0000\u0000\u0565\u055a\u0001\u0000"+
		"\u0000\u0000\u0565\u0566\u0001\u0000\u0000\u0000\u0566\u0567\u0001\u0000"+
		"\u0000\u0000\u0567\u0568\u0005\f\u0000\u0000\u0568\u0569\u0005\u0482\u0000"+
		"\u0000\u0569\u056a\u0003\f\u0006\u0000\u056a\u056d\u0005\u0483\u0000\u0000"+
		"\u056b\u056c\u0005\u0484\u0000\u0000\u056c\u056e\u00034\u001a\u0000\u056d"+
		"\u056b\u0001\u0000\u0000\u0000\u056d\u056e\u0001\u0000\u0000\u0000\u056e"+
		"5\u0001\u0000\u0000\u0000\u056f\u0570\u0003\u0250\u0128\u0000\u05707\u0001"+
		"\u0000\u0000\u0000\u0571\u0572\u0003\u0250\u0128\u0000\u05729\u0001\u0000"+
		"\u0000\u0000\u0573\u0575\u0005\"\u0000\u0000\u0574\u0576\u0003\u028c\u0146"+
		"\u0000\u0575\u0574\u0001\u0000\u0000\u0000\u0575\u0576\u0001\u0000\u0000"+
		"\u0000\u0576\u057a\u0001\u0000\u0000\u0000\u0577\u0578\u0005\u0150\u0000"+
		"\u0000\u0578\u0579\u0005\u0479\u0000\u0000\u0579\u057b\u0007\n\u0000\u0000"+
		"\u057a\u0577\u0001\u0000\u0000\u0000\u057a\u057b\u0001\u0000\u0000\u0000"+
		"\u057b\u057d\u0001\u0000\u0000\u0000\u057c\u057e\u0003F#\u0000\u057d\u057c"+
		"\u0001\u0000\u0000\u0000\u057d\u057e\u0001\u0000\u0000\u0000\u057e\u0582"+
		"\u0001\u0000\u0000\u0000\u057f\u0580\u0005\u00a0\u0000\u0000\u0580\u0581"+
		"\u0005\u0260\u0000\u0000\u0581\u0583\u0007\u000b\u0000\u0000\u0582\u057f"+
		"\u0001\u0000\u0000\u0000\u0582\u0583\u0001\u0000\u0000\u0000\u0583\u0584"+
		"\u0001\u0000\u0000\u0000\u0584\u0585\u0005\u02a3\u0000\u0000\u0585\u058a"+
		"\u0003\u022c\u0116\u0000\u0586\u0587\u0005\u0482\u0000\u0000\u0587\u0588"+
		"\u0003\u0272\u0139\u0000\u0588\u0589\u0005\u0483\u0000\u0000\u0589\u058b"+
		"\u0001\u0000\u0000\u0000\u058a\u0586\u0001\u0000\u0000\u0000\u058a\u058b"+
		"\u0001\u0000\u0000\u0000\u058b\u058c\u0001\u0000\u0000\u0000\u058c\u05a0"+
		"\u0005\f\u0000\u0000\u058d\u058f\u0005\u0482\u0000\u0000\u058e\u0590\u0003"+
		"2\u0019\u0000\u058f\u058e\u0001\u0000\u0000\u0000\u058f\u0590\u0001\u0000"+
		"\u0000\u0000\u0590\u0591\u0001\u0000\u0000\u0000\u0591\u0592\u0003\u00d2"+
		"i\u0000\u0592\u0593\u0005\u0483\u0000\u0000\u0593\u05a1\u0001\u0000\u0000"+
		"\u0000\u0594\u0596\u00032\u0019\u0000\u0595\u0594\u0001\u0000\u0000\u0000"+
		"\u0595\u0596\u0001\u0000\u0000\u0000\u0596\u0597\u0001\u0000\u0000\u0000"+
		"\u0597\u059e\u0003\u00d2i\u0000\u0598\u059a\u0005\u00c0\u0000\u0000\u0599"+
		"\u059b\u0007\f\u0000\u0000\u059a\u0599\u0001\u0000\u0000\u0000\u059a\u059b"+
		"\u0001\u0000\u0000\u0000\u059b\u059c\u0001\u0000\u0000\u0000\u059c\u059d"+
		"\u0005\u001b\u0000\u0000\u059d\u059f\u0005x\u0000\u0000\u059e\u0598\u0001"+
		"\u0000\u0000\u0000\u059e\u059f\u0001\u0000\u0000\u0000\u059f\u05a1\u0001"+
		"\u0000\u0000\u0000\u05a0\u058d\u0001\u0000\u0000\u0000\u05a0\u0595\u0001"+
		"\u0000\u0000\u0000\u05a1;\u0001\u0000\u0000\u0000\u05a2\u05a4\u0005\""+
		"\u0000\u0000\u05a3\u05a5\u0003\u028c\u0146\u0000\u05a4\u05a3\u0001\u0000"+
		"\u0000\u0000\u05a4\u05a5\u0001\u0000\u0000\u0000\u05a5\u05a7\u0001\u0000"+
		"\u0000\u0000\u05a6\u05a8\u0005\u028c\u0000\u0000\u05a7\u05a6\u0001\u0000"+
		"\u0000\u0000\u05a7\u05a8\u0001\u0000\u0000\u0000\u05a8\u05a9\u0001\u0000"+
		"\u0000\u0000\u05a9\u05ab\u0005\u0261\u0000\u0000\u05aa\u05ac\u0003\u028a"+
		"\u0145\u0000\u05ab\u05aa\u0001\u0000\u0000\u0000\u05ab\u05ac\u0001\u0000"+
		"\u0000\u0000\u05ac\u05ad\u0001\u0000\u0000\u0000\u05ad\u05b2\u0003\u022c"+
		"\u0116\u0000\u05ae\u05b1\u0003>\u001f\u0000\u05af\u05b1\u0003p8\u0000"+
		"\u05b0\u05ae\u0001\u0000\u0000\u0000\u05b0\u05af\u0001\u0000\u0000\u0000"+
		"\u05b1\u05b4\u0001\u0000\u0000\u0000\u05b2\u05b0\u0001\u0000\u0000\u0000"+
		"\u05b2\u05b3\u0001\u0000\u0000\u0000\u05b3=\u0001\u0000\u0000\u0000\u05b4"+
		"\u05b2\u0001\u0000\u0000\u0000\u05b5\u05b7\u0005\u01c3\u0000\u0000\u05b6"+
		"\u05b8\u0007\r\u0000\u0000\u05b7\u05b6\u0001\u0000\u0000\u0000\u05b7\u05b8"+
		"\u0001\u0000\u0000\u0000\u05b8\u05b9\u0001\u0000\u0000\u0000\u05b9\u05dd"+
		"\u0003\u0256\u012b\u0000\u05ba\u05bc\u0005o\u0000\u0000\u05bb\u05bd\u0005"+
		"\u0479\u0000\u0000\u05bc\u05bb\u0001\u0000\u0000\u0000\u05bc\u05bd\u0001"+
		"\u0000\u0000\u0000\u05bd\u05be\u0001\u0000\u0000\u0000\u05be\u05dd\u0003"+
		"\u0256\u012b\u0000\u05bf\u05c0\u0005\u020a\u0000\u0000\u05c0\u05dd\u0005"+
		"o\u0000\u0000\u05c1\u05dd\u0005\u020f\u0000\u0000\u05c2\u05c4\u0005n\u0000"+
		"\u0000\u05c3\u05c5\u0005\u0479\u0000\u0000\u05c4\u05c3\u0001\u0000\u0000"+
		"\u0000\u05c4\u05c5\u0001\u0000\u0000\u0000\u05c5\u05c6\u0001\u0000\u0000"+
		"\u0000\u05c6\u05dd\u0003\u0256\u012b\u0000\u05c7\u05c8\u0005\u020a\u0000"+
		"\u0000\u05c8\u05dd\u0005n\u0000\u0000\u05c9\u05dd\u0005\u020e\u0000\u0000"+
		"\u05ca\u05cc\u0005\u0278\u0000\u0000\u05cb\u05cd\u0007\u000e\u0000\u0000"+
		"\u05cc\u05cb\u0001\u0000\u0000\u0000\u05cc\u05cd\u0001\u0000\u0000\u0000"+
		"\u05cd\u05ce\u0001\u0000\u0000\u0000\u05ce\u05dd\u0003\u0256\u012b\u0000"+
		"\u05cf\u05d1\u0005\u015f\u0000\u0000\u05d0\u05d2\u0005\u0479\u0000\u0000"+
		"\u05d1\u05d0\u0001\u0000\u0000\u0000\u05d1\u05d2\u0001\u0000\u0000\u0000"+
		"\u05d2\u05d3\u0001\u0000\u0000\u0000\u05d3\u05dd\u0003\u0256\u012b\u0000"+
		"\u05d4\u05dd\u0005\u020b\u0000\u0000\u05d5\u05dd\u0005\u0182\u0000\u0000"+
		"\u05d6\u05dd\u0005\u020d\u0000\u0000\u05d7\u05d9\u0005\u0250\u0000\u0000"+
		"\u05d8\u05da\u0007\u000e\u0000\u0000\u05d9\u05d8\u0001\u0000\u0000\u0000"+
		"\u05d9\u05da\u0001\u0000\u0000\u0000\u05da\u05db\u0001\u0000\u0000\u0000"+
		"\u05db\u05dd\u0003\u0256\u012b\u0000\u05dc\u05b5\u0001\u0000\u0000\u0000"+
		"\u05dc\u05ba\u0001\u0000\u0000\u0000\u05dc\u05bf\u0001\u0000\u0000\u0000"+
		"\u05dc\u05c1\u0001\u0000\u0000\u0000\u05dc\u05c2\u0001\u0000\u0000\u0000"+
		"\u05dc\u05c7\u0001\u0000\u0000\u0000\u05dc\u05c9\u0001\u0000\u0000\u0000"+
		"\u05dc\u05ca\u0001\u0000\u0000\u0000\u05dc\u05cf\u0001\u0000\u0000\u0000"+
		"\u05dc\u05d4\u0001\u0000\u0000\u0000\u05dc\u05d5\u0001\u0000\u0000\u0000"+
		"\u05dc\u05d6\u0001\u0000\u0000\u0000\u05dc\u05d7\u0001\u0000\u0000\u0000"+
		"\u05dd?\u0001\u0000\u0000\u0000\u05de\u05e0\u0005+\u0000\u0000\u05df\u05de"+
		"\u0001\u0000\u0000\u0000\u05df\u05e0\u0001\u0000\u0000\u0000\u05e0\u05e1"+
		"\u0001\u0000\u0000\u0000\u05e1\u05e3\u0003B!\u0000\u05e2\u05e4\u0005\u0479"+
		"\u0000\u0000\u05e3\u05e2\u0001\u0000\u0000\u0000\u05e3\u05e4\u0001\u0000"+
		"\u0000\u0000\u05e4\u05e7\u0001\u0000\u0000\u0000\u05e5\u05e8\u0003\u023e"+
		"\u011f\u0000\u05e6\u05e8\u0005+\u0000\u0000\u05e7\u05e5\u0001\u0000\u0000"+
		"\u0000\u05e7\u05e6\u0001\u0000\u0000\u0000\u05e8\u0600\u0001\u0000\u0000"+
		"\u0000\u05e9\u05eb\u0005+\u0000\u0000\u05ea\u05e9\u0001\u0000\u0000\u0000"+
		"\u05ea\u05eb\u0001\u0000\u0000\u0000\u05eb\u05ec\u0001\u0000\u0000\u0000"+
		"\u05ec\u05ee\u0005\u001c\u0000\u0000\u05ed\u05ef\u0005\u0479\u0000\u0000"+
		"\u05ee\u05ed\u0001\u0000\u0000\u0000\u05ee\u05ef\u0001\u0000\u0000\u0000"+
		"\u05ef\u05f0\u0001\u0000\u0000\u0000\u05f0\u0600\u0003\u0240\u0120\u0000"+
		"\u05f1\u05f3\u0005+\u0000\u0000\u05f2\u05f1\u0001\u0000\u0000\u0000\u05f2"+
		"\u05f3\u0001\u0000\u0000\u0000\u05f3\u05f4\u0001\u0000\u0000\u0000\u05f4"+
		"\u05f6\u0005\u0195\u0000\u0000\u05f5\u05f7\u0005\u0479\u0000\u0000\u05f6"+
		"\u05f5\u0001\u0000\u0000\u0000\u05f6\u05f7\u0001\u0000\u0000\u0000\u05f7"+
		"\u05f8\u0001\u0000\u0000\u0000\u05f8\u0600\u0005\u0491\u0000\u0000\u05f9"+
		"\u05fa\u0005\u0087\u0000\u0000\u05fa\u05fc\u0005\u021b\u0000\u0000\u05fb"+
		"\u05fd\u0005\u0479\u0000\u0000\u05fc\u05fb\u0001\u0000\u0000\u0000\u05fc"+
		"\u05fd\u0001\u0000\u0000\u0000\u05fd\u05fe\u0001\u0000\u0000\u0000\u05fe"+
		"\u0600\u0007\u000f\u0000\u0000\u05ff\u05df\u0001\u0000\u0000\u0000\u05ff"+
		"\u05ea\u0001\u0000\u0000\u0000\u05ff\u05f2\u0001\u0000\u0000\u0000\u05ff"+
		"\u05f9\u0001\u0000\u0000\u0000\u0600A\u0001\u0000\u0000\u0000\u0601\u0602"+
		"\u0005\u001a\u0000\u0000\u0602\u0607\u0005\u009a\u0000\u0000\u0603\u0607"+
		"\u0005\u0350\u0000\u0000\u0604\u0605\u0005\u00de\u0000\u0000\u0605\u0607"+
		"\u0005\u009a\u0000\u0000\u0606\u0601\u0001\u0000\u0000\u0000\u0606\u0603"+
		"\u0001\u0000\u0000\u0000\u0606\u0604\u0001\u0000\u0000\u0000\u0607C\u0001"+
		"\u0000\u0000\u0000\u0608\u060b\u0005&\u0000\u0000\u0609\u060a\u0005\u0482"+
		"\u0000\u0000\u060a\u060c\u0005\u0483\u0000\u0000\u060b\u0609\u0001\u0000"+
		"\u0000\u0000\u060b\u060c\u0001\u0000\u0000\u0000\u060cE\u0001\u0000\u0000"+
		"\u0000\u060d\u060e\u0005\u0188\u0000\u0000\u060e\u0612\u0005\u0479\u0000"+
		"\u0000\u060f\u0613\u0003\u023a\u011d\u0000\u0610\u0613\u0003D\"\u0000"+
		"\u0611\u0613\u0005%\u0000\u0000\u0612\u060f\u0001\u0000\u0000\u0000\u0612"+
		"\u0610\u0001\u0000\u0000\u0000\u0612\u0611\u0001\u0000\u0000\u0000\u0613"+
		"G\u0001\u0000\u0000\u0000\u0614\u0615\u0005\u0152\u0000\u0000\u0615\u0619"+
		"\u0003J%\u0000\u0616\u0618\u0003L&\u0000\u0617\u0616\u0001\u0000\u0000"+
		"\u0000\u0618\u061b\u0001\u0000\u0000\u0000\u0619\u0617\u0001\u0000\u0000"+
		"\u0000\u0619\u061a\u0001\u0000\u0000\u0000\u061a\u0637\u0001\u0000\u0000"+
		"\u0000\u061b\u0619\u0001\u0000\u0000\u0000\u061c\u061f\u0005\u01a1\u0000"+
		"\u0000\u061d\u0620\u0003\u0256\u012b\u0000\u061e\u0620\u0003\u02ba\u015d"+
		"\u0000\u061f\u061d\u0001\u0000\u0000\u0000\u061f\u061e\u0001\u0000\u0000"+
		"\u0000\u0620\u0621\u0001\u0000\u0000\u0000\u0621\u062a\u0003N\'\u0000"+
		"\u0622\u0623\u0005\u0279\u0000\u0000\u0623\u0627\u0003J%\u0000\u0624\u0626"+
		"\u0003L&\u0000\u0625\u0624\u0001\u0000\u0000\u0000\u0626\u0629\u0001\u0000"+
		"\u0000\u0000\u0627\u0625\u0001\u0000\u0000\u0000\u0627\u0628\u0001\u0000"+
		"\u0000\u0000\u0628\u062b\u0001\u0000\u0000\u0000\u0629\u0627\u0001\u0000"+
		"\u0000\u0000\u062a\u0622\u0001\u0000\u0000\u0000\u062a\u062b\u0001\u0000"+
		"\u0000\u0000\u062b\u0634\u0001\u0000\u0000\u0000\u062c\u062d\u0005\u0198"+
		"\u0000\u0000\u062d\u0631\u0003J%\u0000\u062e\u0630\u0003L&\u0000\u062f"+
		"\u062e\u0001\u0000\u0000\u0000\u0630\u0633\u0001\u0000\u0000\u0000\u0631"+
		"\u062f\u0001\u0000\u0000\u0000\u0631\u0632\u0001\u0000\u0000\u0000\u0632"+
		"\u0635\u0001\u0000\u0000\u0000\u0633\u0631\u0001\u0000\u0000\u0000\u0634"+
		"\u062c\u0001\u0000\u0000\u0000\u0634\u0635\u0001\u0000\u0000\u0000\u0635"+
		"\u0637\u0001\u0000\u0000\u0000\u0636\u0614\u0001\u0000\u0000\u0000\u0636"+
		"\u061c\u0001\u0000\u0000\u0000\u0637I\u0001\u0000\u0000\u0000\u0638\u063d"+
		"\u0005\u013b\u0000\u0000\u0639\u063d\u0003\u025a\u012d\u0000\u063a\u063d"+
		"\u0003\u0256\u012b\u0000\u063b\u063d\u0003\u02ba\u015d\u0000\u063c\u0638"+
		"\u0001\u0000\u0000\u0000\u063c\u0639\u0001\u0000\u0000\u0000\u063c\u063a"+
		"\u0001\u0000\u0000\u0000\u063c\u063b\u0001\u0000\u0000\u0000\u063dK\u0001"+
		"\u0000\u0000\u0000\u063e\u063f\u0005\u0475\u0000\u0000\u063f\u0642\u0005"+
		"V\u0000\u0000\u0640\u0643\u0003\u0256\u012b\u0000\u0641\u0643\u0003\u02ba"+
		"\u015d\u0000\u0642\u0640\u0001\u0000\u0000\u0000\u0642\u0641\u0001\u0000"+
		"\u0000\u0000\u0643\u0644\u0001\u0000\u0000\u0000\u0644\u0645\u0003N\'"+
		"\u0000\u0645M\u0001\u0000\u0000\u0000\u0646\u0654\u0003\u02d2\u0169\u0000"+
		"\u0647\u0654\u0005\u00dd\u0000\u0000\u0648\u0654\u0005\u00f0\u0000\u0000"+
		"\u0649\u0654\u0005\u00f1\u0000\u0000\u064a\u0654\u0005\u00f2\u0000\u0000"+
		"\u064b\u0654\u0005\u00f3\u0000\u0000\u064c\u0654\u0005\u00f4\u0000\u0000"+
		"\u064d\u0654\u0005\u00f5\u0000\u0000\u064e\u0654\u0005\u00f6\u0000\u0000"+
		"\u064f\u0654\u0005\u00f7\u0000\u0000\u0650\u0654\u0005\u00f8\u0000\u0000"+
		"\u0651\u0654\u0005\u00f9\u0000\u0000\u0652\u0654\u0005\u00fa\u0000\u0000"+
		"\u0653\u0646\u0001\u0000\u0000\u0000\u0653\u0647\u0001\u0000\u0000\u0000"+
		"\u0653\u0648\u0001\u0000\u0000\u0000\u0653\u0649\u0001\u0000\u0000\u0000"+
		"\u0653\u064a\u0001\u0000\u0000\u0000\u0653\u064b\u0001\u0000\u0000\u0000"+
		"\u0653\u064c\u0001\u0000\u0000\u0000\u0653\u064d\u0001\u0000\u0000\u0000"+
		"\u0653\u064e\u0001\u0000\u0000\u0000\u0653\u064f\u0001\u0000\u0000\u0000"+
		"\u0653\u0650\u0001\u0000\u0000\u0000\u0653\u0651\u0001\u0000\u0000\u0000"+
		"\u0653\u0652\u0001\u0000\u0000\u0000\u0654O\u0001\u0000\u0000\u0000\u0655"+
		"\u065b\u0005\u0193\u0000\u0000\u0656\u065b\u0005\u018c\u0000\u0000\u0657"+
		"\u0658\u0005\u018c\u0000\u0000\u0658\u0659\u0005v\u0000\u0000\u0659\u065b"+
		"\u0005\u0268\u0000\u0000\u065a\u0655\u0001\u0000\u0000\u0000\u065a\u0656"+
		"\u0001\u0000\u0000\u0000\u065a\u0657\u0001\u0000\u0000\u0000\u065bQ\u0001"+
		"\u0000\u0000\u0000\u065c\u065d\u0005\u00bb\u0000\u0000\u065d\u065e\u0007"+
		"\u0010\u0000\u0000\u065eS\u0001\u0000\u0000\u0000\u065f\u0661\u0005\u01d3"+
		"\u0000\u0000\u0660\u0662\u0005\u0479\u0000\u0000\u0661\u0660\u0001\u0000"+
		"\u0000\u0000\u0661\u0662\u0001\u0000\u0000\u0000\u0662\u0663\u0001\u0000"+
		"\u0000\u0000\u0663\u067e\u0003\u0258\u012c\u0000\u0664\u067e\u0003R)\u0000"+
		"\u0665\u0666\u0005\u00c0\u0000\u0000\u0666\u0667\u0005\u0224\u0000\u0000"+
		"\u0667\u067e\u0003\u0250\u0128\u0000\u0668\u0669\u0005\u0170\u0000\u0000"+
		"\u0669\u067e\u0005\u0491\u0000\u0000\u066a\u067e\u0007\u0011\u0000\u0000"+
		"\u066b\u066d\u0005\u0372\u0000\u0000\u066c\u066e\u0005\u0479\u0000\u0000"+
		"\u066d\u066c\u0001\u0000\u0000\u0000\u066d\u066e\u0001\u0000\u0000\u0000"+
		"\u066e\u066f\u0001\u0000\u0000\u0000\u066f\u067e\u0005\u0491\u0000\u0000"+
		"\u0670\u0672\u0005\u03ee\u0000\u0000\u0671\u0673\u0005\u0479\u0000\u0000"+
		"\u0672\u0671\u0001\u0000\u0000\u0000\u0672\u0673\u0001\u0000\u0000\u0000"+
		"\u0673\u0674\u0001\u0000\u0000\u0000\u0674\u067e\u0005\u0491\u0000\u0000"+
		"\u0675\u0676\u0005\u016a\u0000\u0000\u0676\u0677\u0005\u0479\u0000\u0000"+
		"\u0677\u067e\u0007\u0012\u0000\u0000\u0678\u067c\u0005O\u0000\u0000\u0679"+
		"\u067a\u0005r\u0000\u0000\u067a\u067c\u0005O\u0000\u0000\u067b\u0678\u0001"+
		"\u0000\u0000\u0000\u067b\u0679\u0001\u0000\u0000\u0000\u067c\u067e\u0001"+
		"\u0000\u0000\u0000\u067d\u065f\u0001\u0000\u0000\u0000\u067d\u0664\u0001"+
		"\u0000\u0000\u0000\u067d\u0665\u0001\u0000\u0000\u0000\u067d\u0668\u0001"+
		"\u0000\u0000\u0000\u067d\u066a\u0001\u0000\u0000\u0000\u067d\u066b\u0001"+
		"\u0000\u0000\u0000\u067d\u0670\u0001\u0000\u0000\u0000\u067d\u0675\u0001"+
		"\u0000\u0000\u0000\u067d\u067b\u0001\u0000\u0000\u0000\u067eU\u0001\u0000"+
		"\u0000\u0000\u067f\u0681\u0007\u0013\u0000\u0000\u0680\u067f\u0001\u0000"+
		"\u0000\u0000\u0680\u0681\u0001\u0000\u0000\u0000\u0681\u0682\u0001\u0000"+
		"\u0000\u0000\u0682\u0683\u0003\u0250\u0128\u0000\u0683\u0684\u0003\u0264"+
		"\u0132\u0000\u0684W\u0001\u0000\u0000\u0000\u0685\u0686\u0003\u0250\u0128"+
		"\u0000\u0686\u0687\u0003\u0264\u0132\u0000\u0687Y\u0001\u0000\u0000\u0000"+
		"\u0688\u0689\u0005\u0170\u0000\u0000\u0689\u06a0\u0005\u0491\u0000\u0000"+
		"\u068a\u068b\u0005\u01d4\u0000\u0000\u068b\u06a0\u0005\u00a0\u0000\u0000"+
		"\u068c\u068e\u0005r\u0000\u0000\u068d\u068c\u0001\u0000\u0000\u0000\u068d"+
		"\u068e\u0001\u0000\u0000\u0000\u068e\u068f\u0001\u0000\u0000\u0000\u068f"+
		"\u06a0\u00050\u0000\u0000\u0690\u0691\u0005\u017d\u0000\u0000\u0691\u069b"+
		"\u0005\u00a0\u0000\u0000\u0692\u0693\u0005\u020a\u0000\u0000\u0693\u069b"+
		"\u0005\u00a0\u0000\u0000\u0694\u0695\u0005\u0088\u0000\u0000\u0695\u0696"+
		"\u0005\u00a0\u0000\u0000\u0696\u069b\u0005\u0184\u0000\u0000\u0697\u0698"+
		"\u0005p\u0000\u0000\u0698\u0699\u0005\u00a0\u0000\u0000\u0699\u069b\u0005"+
		"\u0184\u0000\u0000\u069a\u0690\u0001\u0000\u0000\u0000\u069a\u0692\u0001"+
		"\u0000\u0000\u0000\u069a\u0694\u0001\u0000\u0000\u0000\u069a\u0697\u0001"+
		"\u0000\u0000\u0000\u069b\u06a0\u0001\u0000\u0000\u0000\u069c\u069d\u0005"+
		"\u00a0\u0000\u0000\u069d\u069e\u0005\u0260\u0000\u0000\u069e\u06a0\u0007"+
		"\u000b\u0000\u0000\u069f\u0688\u0001\u0000\u0000\u0000\u069f\u068a\u0001"+
		"\u0000\u0000\u0000\u069f\u068d\u0001\u0000\u0000\u0000\u069f\u069a\u0001"+
		"\u0000\u0000\u0000\u069f\u069c\u0001\u0000\u0000\u0000\u06a0[\u0001\u0000"+
		"\u0000\u0000\u06a1\u06a2\u0005\u01be\u0000\u0000\u06a2\u06b0\u0005\u0491"+
		"\u0000\u0000\u06a3\u06a4\u0005(\u0000\u0000\u06a4\u06b0\u0005\u0491\u0000"+
		"\u0000\u06a5\u06a6\u0005\u029d\u0000\u0000\u06a6\u06b0\u0005\u0491\u0000"+
		"\u0000\u06a7\u06a8\u0005\u0228\u0000\u0000\u06a8\u06b0\u0005\u0491\u0000"+
		"\u0000\u06a9\u06aa\u0005\u026c\u0000\u0000\u06aa\u06b0\u0005\u0491\u0000"+
		"\u0000\u06ab\u06ac\u0005\u021f\u0000\u0000\u06ac\u06b0\u0005\u0491\u0000"+
		"\u0000\u06ad\u06ae\u0005\u022e\u0000\u0000\u06ae\u06b0\u0003\u0256\u012b"+
		"\u0000\u06af\u06a1\u0001\u0000\u0000\u0000\u06af\u06a3\u0001\u0000\u0000"+
		"\u0000\u06af\u06a5\u0001\u0000\u0000\u0000\u06af\u06a7\u0001\u0000\u0000"+
		"\u0000\u06af\u06a9\u0001\u0000\u0000\u0000\u06af\u06ab\u0001\u0000\u0000"+
		"\u0000\u06af\u06ad\u0001\u0000\u0000\u0000\u06b0]\u0001\u0000\u0000\u0000"+
		"\u06b1\u06b2\u0005\u0482\u0000\u0000\u06b2\u06b7\u0003`0\u0000\u06b3\u06b4"+
		"\u0005\u0484\u0000\u0000\u06b4\u06b6\u0003`0\u0000\u06b5\u06b3\u0001\u0000"+
		"\u0000\u0000\u06b6\u06b9\u0001\u0000\u0000\u0000\u06b7\u06b5\u0001\u0000"+
		"\u0000\u0000\u06b7\u06b8\u0001\u0000\u0000\u0000\u06b8\u06ba\u0001\u0000"+
		"\u0000\u0000\u06b9\u06b7\u0001\u0000\u0000\u0000\u06ba\u06bb\u0005\u0483"+
		"\u0000\u0000\u06bb_\u0001\u0000\u0000\u0000\u06bc\u06bd\u0003\u0250\u0128"+
		"\u0000\u06bd\u06be\u0003b1\u0000\u06be\u06c2\u0001\u0000\u0000\u0000\u06bf"+
		"\u06c2\u0003f3\u0000\u06c0\u06c2\u0003n7\u0000\u06c1\u06bc\u0001\u0000"+
		"\u0000\u0000\u06c1\u06bf\u0001\u0000\u0000\u0000\u06c1\u06c0\u0001\u0000"+
		"\u0000\u0000\u06c2a\u0001\u0000\u0000\u0000\u06c3\u06c7\u0003\u0264\u0132"+
		"\u0000\u06c4\u06c6\u0003d2\u0000\u06c5\u06c4\u0001\u0000\u0000\u0000\u06c6"+
		"\u06c9\u0001\u0000\u0000\u0000\u06c7\u06c5\u0001\u0000\u0000\u0000\u06c7"+
		"\u06c8\u0001\u0000\u0000\u0000\u06c8c\u0001\u0000\u0000\u0000\u06c9\u06c7"+
		"\u0001\u0000\u0000\u0000\u06ca\u0700\u0003\u0260\u0130\u0000\u06cb\u06cc"+
		"\u0005+\u0000\u0000\u06cc\u0700\u0003\u0282\u0141\u0000\u06cd\u0700\u0005"+
		"\u02a5\u0000\u0000\u06ce\u0700\u0005\u01cb\u0000\u0000\u06cf\u06d4\u0005"+
		"\u0156\u0000\u0000\u06d0\u06d1\u0005v\u0000\u0000\u06d1\u06d2\u0005\u00b8"+
		"\u0000\u0000\u06d2\u06d4\u0003\u0284\u0142\u0000\u06d3\u06cf\u0001\u0000"+
		"\u0000\u0000\u06d3\u06d0\u0001\u0000\u0000\u0000\u06d4\u0700\u0001\u0000"+
		"\u0000\u0000\u06d5\u06d7\u0005\u0082\u0000\u0000\u06d6\u06d5\u0001\u0000"+
		"\u0000\u0000\u06d6\u06d7\u0001\u0000\u0000\u0000\u06d7\u06d8\u0001\u0000"+
		"\u0000\u0000\u06d8\u0700\u0005[\u0000\u0000\u06d9\u06db\u0005\u00b5\u0000"+
		"\u0000\u06da\u06dc\u0005[\u0000\u0000\u06db\u06da\u0001\u0000\u0000\u0000"+
		"\u06db\u06dc\u0001\u0000\u0000\u0000\u06dc\u0700\u0001\u0000\u0000\u0000"+
		"\u06dd\u06de\u0005\u0170\u0000\u0000\u06de\u0700\u0005\u0491\u0000\u0000"+
		"\u06df\u06e0\u0005\u016e\u0000\u0000\u06e0\u0700\u0007\u0014\u0000\u0000"+
		"\u06e1\u06e2\u0005\u027f\u0000\u0000\u06e2\u0700\u0007\u0015\u0000\u0000"+
		"\u06e3\u0700\u0003h4\u0000\u06e4\u06e5\u0005\u001c\u0000\u0000\u06e5\u0700"+
		"\u0003\u0240\u0120\u0000\u06e6\u06e7\u0005F\u0000\u0000\u06e7\u06e9\u0005"+
		"\b\u0000\u0000\u06e8\u06e6\u0001\u0000\u0000\u0000\u06e8\u06e9\u0001\u0000"+
		"\u0000\u0000\u06e9\u06ea\u0001\u0000\u0000\u0000\u06ea\u06eb\u0005\f\u0000"+
		"\u0000\u06eb\u06ec\u0005\u0482\u0000\u0000\u06ec\u06ed\u0003\u02ba\u015d"+
		"\u0000\u06ed\u06ef\u0005\u0483\u0000\u0000\u06ee\u06f0\u0007\u0016\u0000"+
		"\u0000\u06ef\u06ee\u0001\u0000\u0000\u0000\u06ef\u06f0\u0001\u0000\u0000"+
		"\u0000\u06f0\u0700\u0001\u0000\u0000\u0000\u06f1\u06f2\u0005\u00ef\u0000"+
		"\u0000\u06f2\u06f3\u0005+\u0000\u0000\u06f3\u0700\u0005\u02a1\u0000\u0000"+
		"\u06f4\u06f6\u0005\u001f\u0000\u0000\u06f5\u06f7\u0003\u0250\u0128\u0000"+
		"\u06f6\u06f5\u0001\u0000\u0000\u0000\u06f6\u06f7\u0001\u0000\u0000\u0000"+
		"\u06f7\u06f9\u0001\u0000\u0000\u0000\u06f8\u06f4\u0001\u0000\u0000\u0000"+
		"\u06f8\u06f9\u0001\u0000\u0000\u0000\u06f9\u06fa\u0001\u0000\u0000\u0000"+
		"\u06fa\u06fb\u0005\u001b\u0000\u0000\u06fb\u06fc\u0005\u0482\u0000\u0000"+
		"\u06fc\u06fd\u0003\u02ba\u015d\u0000\u06fd\u06fe\u0005\u0483\u0000\u0000"+
		"\u06fe\u0700\u0001\u0000\u0000\u0000\u06ff\u06ca\u0001\u0000\u0000\u0000"+
		"\u06ff\u06cb\u0001\u0000\u0000\u0000\u06ff\u06cd\u0001\u0000\u0000\u0000"+
		"\u06ff\u06ce\u0001\u0000\u0000\u0000\u06ff\u06d3\u0001\u0000\u0000\u0000"+
		"\u06ff\u06d6\u0001\u0000\u0000\u0000\u06ff\u06d9\u0001\u0000\u0000\u0000"+
		"\u06ff\u06dd\u0001\u0000\u0000\u0000\u06ff\u06df\u0001\u0000\u0000\u0000"+
		"\u06ff\u06e1\u0001\u0000\u0000\u0000\u06ff\u06e3\u0001\u0000\u0000\u0000"+
		"\u06ff\u06e4\u0001\u0000\u0000\u0000\u06ff\u06e8\u0001\u0000\u0000\u0000"+
		"\u06ff\u06f1\u0001\u0000\u0000\u0000\u06ff\u06f8\u0001\u0000\u0000\u0000"+
		"\u0700e\u0001\u0000\u0000\u0000\u0701\u0703\u0005\u001f\u0000\u0000\u0702"+
		"\u0704\u0003\u0250\u0128\u0000\u0703\u0702\u0001\u0000\u0000\u0000\u0703"+
		"\u0704\u0001\u0000\u0000\u0000\u0704\u0706\u0001\u0000\u0000\u0000\u0705"+
		"\u0701\u0001\u0000\u0000\u0000\u0705\u0706\u0001\u0000\u0000\u0000\u0706"+
		"\u0707\u0001\u0000\u0000\u0000\u0707\u0708\u0005\u0082\u0000\u0000\u0708"+
		"\u070a\u0005[\u0000\u0000\u0709\u070b\u0003\u0250\u0128\u0000\u070a\u0709"+
		"\u0001\u0000\u0000\u0000\u070a\u070b\u0001\u0000\u0000\u0000\u070b\u070d"+
		"\u0001\u0000\u0000\u0000\u070c\u070e\u0003R)\u0000\u070d\u070c\u0001\u0000"+
		"\u0000\u0000\u070d\u070e\u0001\u0000\u0000\u0000\u070e\u070f\u0001\u0000"+
		"\u0000\u0000\u070f\u0713\u0003\u0276\u013b\u0000\u0710\u0712\u0003T*\u0000"+
		"\u0711\u0710\u0001\u0000\u0000\u0000\u0712\u0715\u0001\u0000\u0000\u0000"+
		"\u0713\u0711\u0001\u0000\u0000\u0000\u0713\u0714\u0001\u0000\u0000\u0000"+
		"\u0714\u0747\u0001\u0000\u0000\u0000\u0715\u0713\u0001\u0000\u0000\u0000"+
		"\u0716\u0718\u0005\u001f\u0000\u0000\u0717\u0719\u0003\u0250\u0128\u0000"+
		"\u0718\u0717\u0001\u0000\u0000\u0000\u0718\u0719\u0001\u0000\u0000\u0000"+
		"\u0719\u071b\u0001\u0000\u0000\u0000\u071a\u0716\u0001\u0000\u0000\u0000"+
		"\u071a\u071b\u0001\u0000\u0000\u0000\u071b\u071c\u0001\u0000\u0000\u0000"+
		"\u071c\u071e\u0005\u00b5\u0000\u0000\u071d\u071f\u0007\u0017\u0000\u0000"+
		"\u071e\u071d\u0001\u0000\u0000\u0000\u071e\u071f\u0001\u0000\u0000\u0000"+
		"\u071f\u0721\u0001\u0000\u0000\u0000\u0720\u0722\u0003\u0250\u0128\u0000"+
		"\u0721\u0720\u0001\u0000\u0000\u0000\u0721\u0722\u0001\u0000\u0000\u0000"+
		"\u0722\u0724\u0001\u0000\u0000\u0000\u0723\u0725\u0003R)\u0000\u0724\u0723"+
		"\u0001\u0000\u0000\u0000\u0724\u0725\u0001\u0000\u0000\u0000\u0725\u0726"+
		"\u0001\u0000\u0000\u0000\u0726\u072a\u0003\u0276\u013b\u0000\u0727\u0729"+
		"\u0003T*\u0000\u0728\u0727\u0001\u0000\u0000\u0000\u0729\u072c\u0001\u0000"+
		"\u0000\u0000\u072a\u0728\u0001\u0000\u0000\u0000\u072a\u072b\u0001\u0000"+
		"\u0000\u0000\u072b\u0747\u0001\u0000\u0000\u0000\u072c\u072a\u0001\u0000"+
		"\u0000\u0000\u072d\u072f\u0005\u001f\u0000\u0000\u072e\u0730\u0003\u0250"+
		"\u0128\u0000\u072f\u072e\u0001\u0000\u0000\u0000\u072f\u0730\u0001\u0000"+
		"\u0000\u0000\u0730\u0732\u0001\u0000\u0000\u0000\u0731\u072d\u0001\u0000"+
		"\u0000\u0000\u0731\u0732\u0001\u0000\u0000\u0000\u0732\u0733\u0001\u0000"+
		"\u0000\u0000\u0733\u0734\u0005C\u0000\u0000\u0734\u0736\u0005[\u0000\u0000"+
		"\u0735\u0737\u0003\u0250\u0128\u0000\u0736\u0735\u0001\u0000\u0000\u0000"+
		"\u0736\u0737\u0001\u0000\u0000\u0000\u0737\u0738\u0001\u0000\u0000\u0000"+
		"\u0738\u0739\u0003\u0276\u013b\u0000\u0739\u073a\u0003h4\u0000\u073a\u0747"+
		"\u0001\u0000\u0000\u0000\u073b\u073d\u0005\u001f\u0000\u0000\u073c\u073e"+
		"\u0003\u0250\u0128\u0000\u073d\u073c\u0001\u0000\u0000\u0000\u073d\u073e"+
		"\u0001\u0000\u0000\u0000\u073e\u0740\u0001\u0000\u0000\u0000\u073f\u073b"+
		"\u0001\u0000\u0000\u0000\u073f\u0740\u0001\u0000\u0000\u0000\u0740\u0741"+
		"\u0001\u0000\u0000\u0000\u0741\u0742\u0005\u001b\u0000\u0000\u0742\u0743"+
		"\u0005\u0482\u0000\u0000\u0743\u0744\u0003\u02ba\u015d\u0000\u0744\u0745"+
		"\u0005\u0483\u0000\u0000\u0745\u0747\u0001\u0000\u0000\u0000\u0746\u0705"+
		"\u0001\u0000\u0000\u0000\u0746\u071a\u0001\u0000\u0000\u0000\u0746\u0731"+
		"\u0001\u0000\u0000\u0000\u0746\u073f\u0001\u0000\u0000\u0000\u0747g\u0001"+
		"\u0000\u0000\u0000\u0748\u0749\u0005\u0089\u0000\u0000\u0749\u074b\u0003"+
		"\u022e\u0117\u0000\u074a\u074c\u0003\u0276\u013b\u0000\u074b\u074a\u0001"+
		"\u0000\u0000\u0000\u074b\u074c\u0001\u0000\u0000\u0000\u074c\u074f\u0001"+
		"\u0000\u0000\u0000\u074d\u074e\u0005m\u0000\u0000\u074e\u0750\u0007\u0018"+
		"\u0000\u0000\u074f\u074d\u0001\u0000\u0000\u0000\u074f\u0750\u0001\u0000"+
		"\u0000\u0000\u0750\u0752\u0001\u0000\u0000\u0000\u0751\u0753\u0003j5\u0000"+
		"\u0752\u0751\u0001\u0000\u0000\u0000\u0752\u0753\u0001\u0000\u0000\u0000"+
		"\u0753i\u0001\u0000\u0000\u0000\u0754\u0755\u0005v\u0000\u0000\u0755\u0756"+
		"\u0005-\u0000\u0000\u0756\u075a\u0003l6\u0000\u0757\u0758\u0005v\u0000"+
		"\u0000\u0758\u0759\u0005\u00b8\u0000\u0000\u0759\u075b\u0003l6\u0000\u075a"+
		"\u0757\u0001\u0000\u0000\u0000\u075a\u075b\u0001\u0000\u0000\u0000\u075b"+
		"\u0765\u0001\u0000\u0000\u0000\u075c\u075d\u0005v\u0000\u0000\u075d\u075e"+
		"\u0005\u00b8\u0000\u0000\u075e\u0762\u0003l6\u0000\u075f\u0760\u0005v"+
		"\u0000\u0000\u0760\u0761\u0005-\u0000\u0000\u0761\u0763\u0003l6\u0000"+
		"\u0762\u075f\u0001\u0000\u0000\u0000\u0762\u0763\u0001\u0000\u0000\u0000"+
		"\u0763\u0765\u0001\u0000\u0000\u0000\u0764\u0754\u0001\u0000\u0000\u0000"+
		"\u0764\u075c\u0001\u0000\u0000\u0000\u0765k\u0001\u0000\u0000\u0000\u0766"+
		"\u076d\u0005\u0091\u0000\u0000\u0767\u076d\u0005\u0016\u0000\u0000\u0768"+
		"\u0769\u0005\u009a\u0000\u0000\u0769\u076d\u0005t\u0000\u0000\u076a\u076b"+
		"\u0005\u020a\u0000\u0000\u076b\u076d\u0005\u014d\u0000\u0000\u076c\u0766"+
		"\u0001\u0000\u0000\u0000\u076c\u0767\u0001\u0000\u0000\u0000\u076c\u0768"+
		"\u0001\u0000\u0000\u0000\u076c\u076a\u0001\u0000\u0000\u0000\u076dm\u0001"+
		"\u0000\u0000\u0000\u076e\u0770\u0007\u0017\u0000\u0000\u076f\u0771\u0003"+
		"\u0250\u0128\u0000\u0770\u076f\u0001\u0000\u0000\u0000\u0770\u0771\u0001"+
		"\u0000\u0000\u0000\u0771\u0773\u0001\u0000\u0000\u0000\u0772\u0774\u0003"+
		"R)\u0000\u0773\u0772\u0001\u0000\u0000\u0000\u0773\u0774\u0001\u0000\u0000"+
		"\u0000\u0774\u0775\u0001\u0000\u0000\u0000\u0775\u0779\u0003\u0276\u013b"+
		"\u0000\u0776\u0778\u0003T*\u0000\u0777\u0776\u0001\u0000\u0000\u0000\u0778"+
		"\u077b\u0001\u0000\u0000\u0000\u0779\u0777\u0001\u0000\u0000\u0000\u0779"+
		"\u077a\u0001\u0000\u0000\u0000\u077a\u078b\u0001\u0000\u0000\u0000\u077b"+
		"\u0779\u0001\u0000\u0000\u0000\u077c\u077e\u0007\u0019\u0000\u0000\u077d"+
		"\u077f\u0007\u0017\u0000\u0000\u077e\u077d\u0001\u0000\u0000\u0000\u077e"+
		"\u077f\u0001\u0000\u0000\u0000\u077f\u0781\u0001\u0000\u0000\u0000\u0780"+
		"\u0782\u0003\u0250\u0128\u0000\u0781\u0780\u0001\u0000\u0000\u0000\u0781"+
		"\u0782\u0001\u0000\u0000\u0000\u0782\u0783\u0001\u0000\u0000\u0000\u0783"+
		"\u0787\u0003\u0276\u013b\u0000\u0784\u0786\u0003T*\u0000\u0785\u0784\u0001"+
		"\u0000\u0000\u0000\u0786\u0789\u0001\u0000\u0000\u0000\u0787\u0785\u0001"+
		"\u0000\u0000\u0000\u0787\u0788\u0001\u0000\u0000\u0000\u0788\u078b\u0001"+
		"\u0000\u0000\u0000\u0789\u0787\u0001\u0000\u0000\u0000\u078a\u076e\u0001"+
		"\u0000\u0000\u0000\u078a\u077c\u0001\u0000\u0000\u0000\u078bo\u0001\u0000"+
		"\u0000\u0000\u078c\u078e\u0005\u0199\u0000\u0000\u078d\u078f\u0005\u0479"+
		"\u0000\u0000\u078e\u078d\u0001\u0000\u0000\u0000\u078e\u078f\u0001\u0000"+
		"\u0000\u0000\u078f\u0791\u0001\u0000\u0000\u0000\u0790\u0792\u0003\u0242"+
		"\u0121\u0000\u0791\u0790\u0001\u0000\u0000\u0000\u0791\u0792\u0001\u0000"+
		"\u0000\u0000\u0792\u084c\u0001\u0000\u0000\u0000\u0793\u0795\u0005\u0372"+
		"\u0000\u0000\u0794\u0796\u0005\u0479\u0000\u0000\u0795\u0794\u0001\u0000"+
		"\u0000\u0000\u0795\u0796\u0001\u0000\u0000\u0000\u0796\u0797\u0001\u0000"+
		"\u0000\u0000\u0797\u084c\u0005\u0491\u0000\u0000\u0798\u079a\u0005\u0155"+
		"\u0000\u0000\u0799\u079b\u0005\u0479\u0000\u0000\u079a\u0799\u0001\u0000"+
		"\u0000\u0000\u079a\u079b\u0001\u0000\u0000\u0000\u079b\u079c\u0001\u0000"+
		"\u0000\u0000\u079c\u084c\u0003\u0256\u012b\u0000\u079d\u079f\u0005\u0156"+
		"\u0000\u0000\u079e\u07a0\u0005\u0479\u0000\u0000\u079f\u079e\u0001\u0000"+
		"\u0000\u0000\u079f\u07a0\u0001\u0000\u0000\u0000\u07a0\u07a1\u0001\u0000"+
		"\u0000\u0000\u07a1\u084c\u0003\u0256\u012b\u0000\u07a2\u07a4\u0005\u0157"+
		"\u0000\u0000\u07a3\u07a5\u0005\u0479\u0000\u0000\u07a4\u07a3\u0001\u0000"+
		"\u0000\u0000\u07a4\u07a5\u0001\u0000\u0000\u0000\u07a5\u07a6\u0001\u0000"+
		"\u0000\u0000\u07a6\u084c\u0003\u0256\u012b\u0000\u07a7\u07a9\u0005+\u0000"+
		"\u0000\u07a8\u07a7\u0001\u0000\u0000\u0000\u07a8\u07a9\u0001\u0000\u0000"+
		"\u0000\u07a9\u07aa\u0001\u0000\u0000\u0000\u07aa\u07ac\u0003B!\u0000\u07ab"+
		"\u07ad\u0005\u0479\u0000\u0000\u07ac\u07ab\u0001\u0000\u0000\u0000\u07ac"+
		"\u07ad\u0001\u0000\u0000\u0000\u07ad\u07b0\u0001\u0000\u0000\u0000\u07ae"+
		"\u07b1\u0003\u023e\u011f\u0000\u07af\u07b1\u0005+\u0000\u0000\u07b0\u07ae"+
		"\u0001\u0000\u0000\u0000\u07b0\u07af\u0001\u0000\u0000\u0000\u07b1\u084c"+
		"\u0001\u0000\u0000\u0000\u07b2\u07b4\u0007\u001a\u0000\u0000\u07b3\u07b5"+
		"\u0005\u0479\u0000\u0000\u07b4\u07b3\u0001\u0000\u0000\u0000\u07b4\u07b5"+
		"\u0001\u0000\u0000\u0000\u07b5\u07b6\u0001\u0000\u0000\u0000\u07b6\u084c"+
		"\u0007\u001b\u0000\u0000\u07b7\u07b9\u0005+\u0000\u0000\u07b8\u07b7\u0001"+
		"\u0000\u0000\u0000\u07b8\u07b9\u0001\u0000\u0000\u0000\u07b9\u07ba\u0001"+
		"\u0000\u0000\u0000\u07ba\u07bc\u0005\u001c\u0000\u0000\u07bb\u07bd\u0005"+
		"\u0479\u0000\u0000\u07bc\u07bb\u0001\u0000\u0000\u0000\u07bc\u07bd\u0001"+
		"\u0000\u0000\u0000\u07bd\u07be\u0001\u0000\u0000\u0000\u07be\u084c\u0003"+
		"\u0240\u0120\u0000\u07bf\u07c1\u0005\u0170\u0000\u0000\u07c0\u07c2\u0005"+
		"\u0479\u0000\u0000\u07c1\u07c0\u0001\u0000\u0000\u0000\u07c1\u07c2\u0001"+
		"\u0000\u0000\u0000\u07c2\u07c3\u0001\u0000\u0000\u0000\u07c3\u084c\u0005"+
		"\u0491\u0000\u0000\u07c4\u07c6\u0005\u0175\u0000\u0000\u07c5\u07c7\u0005"+
		"\u0479\u0000\u0000\u07c6\u07c5\u0001\u0000\u0000\u0000\u07c6\u07c7\u0001"+
		"\u0000\u0000\u0000\u07c7\u07c8\u0001\u0000\u0000\u0000\u07c8\u084c\u0007"+
		"\u001c\u0000\u0000\u07c9\u07cb\u0005\u0178\u0000\u0000\u07ca\u07cc\u0005"+
		"\u0479\u0000\u0000\u07cb\u07ca\u0001\u0000\u0000\u0000\u07cb\u07cc\u0001"+
		"\u0000\u0000\u0000\u07cc\u07cd\u0001\u0000\u0000\u0000\u07cd\u084c\u0005"+
		"\u0491\u0000\u0000\u07ce\u07cf\u0007\u001d\u0000\u0000\u07cf\u07d1\u0005"+
		"\u018b\u0000\u0000\u07d0\u07d2\u0005\u0479\u0000\u0000\u07d1\u07d0\u0001"+
		"\u0000\u0000\u0000\u07d1\u07d2\u0001\u0000\u0000\u0000\u07d2\u07d3\u0001"+
		"\u0000\u0000\u0000\u07d3\u084c\u0005\u0491\u0000\u0000\u07d4\u07d6\u0005"+
		"\u0189\u0000\u0000\u07d5\u07d7\u0005\u0479\u0000\u0000\u07d6\u07d5\u0001"+
		"\u0000\u0000\u0000\u07d6\u07d7\u0001\u0000\u0000\u0000\u07d7\u07d8\u0001"+
		"\u0000\u0000\u0000\u07d8\u084c\u0007\u001b\u0000\u0000\u07d9\u07db\u0005"+
		"\u0195\u0000\u0000\u07da\u07dc\u0005\u0479\u0000\u0000\u07db\u07da\u0001"+
		"\u0000\u0000\u0000\u07db\u07dc\u0001\u0000\u0000\u0000\u07dc\u07dd\u0001"+
		"\u0000\u0000\u0000\u07dd\u084c\u0005\u0491\u0000\u0000\u07de\u07e0\u0003"+
		"\u0246\u0123\u0000\u07df\u07e1\u0005\u0479\u0000\u0000\u07e0\u07df\u0001"+
		"\u0000\u0000\u0000\u07e0\u07e1\u0001\u0000\u0000\u0000\u07e1\u07e2\u0001"+
		"\u0000\u0000\u0000\u07e2\u07e3\u0007\u0012\u0000\u0000\u07e3\u084c\u0001"+
		"\u0000\u0000\u0000\u07e4\u07e6\u0007\u001e\u0000\u0000\u07e5\u07e7\u0005"+
		"\u0479\u0000\u0000\u07e6\u07e5\u0001\u0000\u0000\u0000\u07e6\u07e7\u0001"+
		"\u0000\u0000\u0000\u07e7\u07e8\u0001\u0000\u0000\u0000\u07e8\u084c\u0007"+
		"\u001b\u0000\u0000\u07e9\u07eb\u0007\u001f\u0000\u0000\u07ea\u07ec\u0005"+
		"\u0479\u0000\u0000\u07eb\u07ea\u0001\u0000\u0000\u0000\u07eb\u07ec\u0001"+
		"\u0000\u0000\u0000\u07ec\u07ed\u0001\u0000\u0000\u0000\u07ed\u084c\u0003"+
		"\u0256\u012b\u0000\u07ee\u07f0\u0005\u0196\u0000\u0000\u07ef\u07f1\u0005"+
		"\u0479\u0000\u0000\u07f0\u07ef\u0001\u0000\u0000\u0000\u07f0\u07f1\u0001"+
		"\u0000\u0000\u0000\u07f1\u07f2\u0001\u0000\u0000\u0000\u07f2\u084c\u0003"+
		"\u0256\u012b\u0000\u07f3\u07f4\u0005Q\u0000\u0000\u07f4\u07f6\u0005\u018b"+
		"\u0000\u0000\u07f5\u07f7\u0005\u0479\u0000\u0000\u07f6\u07f5\u0001\u0000"+
		"\u0000\u0000\u07f6\u07f7\u0001\u0000\u0000\u0000\u07f7\u07f8\u0001\u0000"+
		"\u0000\u0000\u07f8\u084c\u0005\u0491\u0000\u0000\u07f9\u07fb\u0005\u01c7"+
		"\u0000\u0000\u07fa\u07fc\u0005\u0479\u0000\u0000\u07fb\u07fa\u0001\u0000"+
		"\u0000\u0000\u07fb\u07fc\u0001\u0000\u0000\u0000\u07fc\u07fd\u0001\u0000"+
		"\u0000\u0000\u07fd\u084c\u0007 \u0000\u0000\u07fe\u0800\u0005\u01d3\u0000"+
		"\u0000\u07ff\u0801\u0005\u0479\u0000\u0000\u0800\u07ff\u0001\u0000\u0000"+
		"\u0000\u0800\u0801\u0001\u0000\u0000\u0000\u0801\u0802\u0001\u0000\u0000"+
		"\u0000\u0802\u084c\u0003\u0258\u012c\u0000\u0803\u0805\u0005\u01f5\u0000"+
		"\u0000\u0804\u0806\u0005\u0479\u0000\u0000\u0805\u0804\u0001\u0000\u0000"+
		"\u0000\u0805\u0806\u0001\u0000\u0000\u0000\u0806\u0807\u0001\u0000\u0000"+
		"\u0000\u0807\u084c\u0003\u0256\u012b\u0000\u0808\u080a\u0005\u01ff\u0000"+
		"\u0000\u0809\u080b\u0005\u0479\u0000\u0000\u080a\u0809\u0001\u0000\u0000"+
		"\u0000\u080a\u080b\u0001\u0000\u0000\u0000\u080b\u080c\u0001\u0000\u0000"+
		"\u0000\u080c\u084c\u0003\u0256\u012b\u0000\u080d\u080f\u0005\u0220\u0000"+
		"\u0000\u080e\u0810\u0005\u0479\u0000\u0000\u080f\u080e\u0001\u0000\u0000"+
		"\u0000\u080f\u0810\u0001\u0000\u0000\u0000\u0810\u0811\u0001\u0000\u0000"+
		"\u0000\u0811\u084c\u0007\u000f\u0000\u0000\u0812\u0814\u0005\u0228\u0000"+
		"\u0000\u0813\u0815\u0005\u0479\u0000\u0000\u0814\u0813\u0001\u0000\u0000"+
		"\u0000\u0814\u0815\u0001\u0000\u0000\u0000\u0815\u0816\u0001\u0000\u0000"+
		"\u0000\u0816\u084c\u0005\u0491\u0000\u0000\u0817\u0819\u0005\u025c\u0000"+
		"\u0000\u0818\u081a\u0005\u0479\u0000\u0000\u0819\u0818\u0001\u0000\u0000"+
		"\u0000\u0819\u081a\u0001\u0000\u0000\u0000\u081a\u081b\u0001\u0000\u0000"+
		"\u0000\u081b\u084c\u0007!\u0000\u0000\u081c\u081d\u0005\u0278\u0000\u0000"+
		"\u081d\u084c\u0005\u0290\u0000\u0000\u081e\u0820\u0005\u03ee\u0000\u0000"+
		"\u081f\u0821\u0005\u0479\u0000\u0000\u0820\u081f\u0001\u0000\u0000\u0000"+
		"\u0820\u0821\u0001\u0000\u0000\u0000\u0821\u0822\u0001\u0000\u0000\u0000"+
		"\u0822\u084c\u0005\u0491\u0000\u0000\u0823\u0825\u0005\u027a\u0000\u0000"+
		"\u0824\u0826\u0005\u0479\u0000\u0000\u0825\u0824\u0001\u0000\u0000\u0000"+
		"\u0825\u0826\u0001\u0000\u0000\u0000\u0826\u0827\u0001\u0000\u0000\u0000"+
		"\u0827\u084c\u0007\u000f\u0000\u0000\u0828\u082a\u0005\u027b\u0000\u0000"+
		"\u0829\u082b\u0005\u0479\u0000\u0000\u082a\u0829\u0001\u0000\u0000\u0000"+
		"\u082a\u082b\u0001\u0000\u0000\u0000\u082b\u082c\u0001\u0000\u0000\u0000"+
		"\u082c\u084c\u0007\u000f\u0000\u0000\u082d\u082f\u0005\u027c\u0000\u0000"+
		"\u082e\u0830\u0005\u0479\u0000\u0000\u082f\u082e\u0001\u0000\u0000\u0000"+
		"\u082f\u0830\u0001\u0000\u0000\u0000\u0830\u0833\u0001\u0000\u0000\u0000"+
		"\u0831\u0834\u0005+\u0000\u0000\u0832\u0834\u0003\u0256\u012b\u0000\u0833"+
		"\u0831\u0001\u0000\u0000\u0000\u0833\u0832\u0001\u0000\u0000\u0000\u0834"+
		"\u084c\u0001\u0000\u0000\u0000\u0835\u0836\u0005\u028a\u0000\u0000\u0836"+
		"\u0838\u0003\u0250\u0128\u0000\u0837\u0839\u0003t:\u0000\u0838\u0837\u0001"+
		"\u0000\u0000\u0000\u0838\u0839\u0001\u0000\u0000\u0000\u0839\u084c\u0001"+
		"\u0000\u0000\u0000\u083a\u083b\u0005\u028b\u0000\u0000\u083b\u083c\u0005"+
		"\u0479\u0000\u0000\u083c\u084c\u0003r9\u0000\u083d\u084c\u0003t:\u0000"+
		"\u083e\u0840\u0005\u0291\u0000\u0000\u083f\u0841\u0005\u0479\u0000\u0000"+
		"\u0840\u083f\u0001\u0000\u0000\u0000\u0840\u0841\u0001\u0000\u0000\u0000"+
		"\u0841\u0842\u0001\u0000\u0000\u0000\u0842\u084c\u0007\u001b\u0000\u0000"+
		"\u0843\u0845\u0005\u00b4\u0000\u0000\u0844\u0846\u0005\u0479\u0000\u0000"+
		"\u0845\u0844\u0001\u0000\u0000\u0000\u0845\u0846\u0001\u0000\u0000\u0000"+
		"\u0846\u0847\u0001\u0000\u0000\u0000\u0847\u0848\u0005\u0482\u0000\u0000"+
		"\u0848\u0849\u0003\u0274\u013a\u0000\u0849\u084a\u0005\u0483\u0000\u0000"+
		"\u084a\u084c\u0001\u0000\u0000\u0000\u084b\u078c\u0001\u0000\u0000\u0000"+
		"\u084b\u0793\u0001\u0000\u0000\u0000\u084b\u0798\u0001\u0000\u0000\u0000"+
		"\u084b\u079d\u0001\u0000\u0000\u0000\u084b\u07a2\u0001\u0000\u0000\u0000"+
		"\u084b\u07a8\u0001\u0000\u0000\u0000\u084b\u07b2\u0001\u0000\u0000\u0000"+
		"\u084b\u07b8\u0001\u0000\u0000\u0000\u084b\u07bf\u0001\u0000\u0000\u0000"+
		"\u084b\u07c4\u0001\u0000\u0000\u0000\u084b\u07c9\u0001\u0000\u0000\u0000"+
		"\u084b\u07ce\u0001\u0000\u0000\u0000\u084b\u07d4\u0001\u0000\u0000\u0000"+
		"\u084b\u07d9\u0001\u0000\u0000\u0000\u084b\u07de\u0001\u0000\u0000\u0000"+
		"\u084b\u07e4\u0001\u0000\u0000\u0000\u084b\u07e9\u0001\u0000\u0000\u0000"+
		"\u084b\u07ee\u0001\u0000\u0000\u0000\u084b\u07f3\u0001\u0000\u0000\u0000"+
		"\u084b\u07f9\u0001\u0000\u0000\u0000\u084b\u07fe\u0001\u0000\u0000\u0000"+
		"\u084b\u0803\u0001\u0000\u0000\u0000\u084b\u0808\u0001\u0000\u0000\u0000"+
		"\u084b\u080d\u0001\u0000\u0000\u0000\u084b\u0812\u0001\u0000\u0000\u0000"+
		"\u084b\u0817\u0001\u0000\u0000\u0000\u084b\u081c\u0001\u0000\u0000\u0000"+
		"\u084b\u081e\u0001\u0000\u0000\u0000\u084b\u0823\u0001\u0000\u0000\u0000"+
		"\u084b\u0828\u0001\u0000\u0000\u0000\u084b\u082d\u0001\u0000\u0000\u0000"+
		"\u084b\u0835\u0001\u0000\u0000\u0000\u084b\u083a\u0001\u0000\u0000\u0000"+
		"\u084b\u083d\u0001\u0000\u0000\u0000\u084b\u083e\u0001\u0000\u0000\u0000"+
		"\u084b\u0843\u0001\u0000\u0000\u0000\u084cq\u0001\u0000\u0000\u0000\u084d"+
		"\u084e\u0007\"\u0000\u0000\u084es\u0001\u0000\u0000\u0000\u084f\u0850"+
		"\u0005\u027f\u0000\u0000\u0850\u0851\u0007\u0015\u0000\u0000\u0851u\u0001"+
		"\u0000\u0000\u0000\u0852\u0853\u0005\u0081\u0000\u0000\u0853\u0854\u0005"+
		"\u0014\u0000\u0000\u0854\u0857\u0003x<\u0000\u0855\u0856\u0005\u0227\u0000"+
		"\u0000\u0856\u0858\u0003\u0256\u012b\u0000\u0857\u0855\u0001\u0000\u0000"+
		"\u0000\u0857\u0858\u0001\u0000\u0000\u0000\u0858\u0860\u0001\u0000\u0000"+
		"\u0000\u0859\u085a\u0005\u0284\u0000\u0000\u085a\u085b\u0005\u0014\u0000"+
		"\u0000\u085b\u085e\u0003z=\u0000\u085c\u085d\u0005\u0285\u0000\u0000\u085d"+
		"\u085f\u0003\u0256\u012b\u0000\u085e\u085c\u0001\u0000\u0000\u0000\u085e"+
		"\u085f\u0001\u0000\u0000\u0000\u085f\u0861\u0001\u0000\u0000\u0000\u0860"+
		"\u0859\u0001\u0000\u0000\u0000\u0860\u0861\u0001\u0000\u0000\u0000\u0861"+
		"\u086d\u0001\u0000\u0000\u0000\u0862\u0863\u0005\u0482\u0000\u0000\u0863"+
		"\u0868\u0003|>\u0000\u0864\u0865\u0005\u0484\u0000\u0000\u0865\u0867\u0003"+
		"|>\u0000\u0866\u0864\u0001\u0000\u0000\u0000\u0867\u086a\u0001\u0000\u0000"+
		"\u0000\u0868\u0866\u0001\u0000\u0000\u0000\u0868\u0869\u0001\u0000\u0000"+
		"\u0000\u0869\u086b\u0001\u0000\u0000\u0000\u086a\u0868\u0001\u0000\u0000"+
		"\u0000\u086b\u086c\u0005\u0483\u0000\u0000\u086c\u086e\u0001\u0000\u0000"+
		"\u0000\u086d\u0862\u0001\u0000\u0000\u0000\u086d\u086e\u0001\u0000\u0000"+
		"\u0000\u086ew\u0001\u0000\u0000\u0000\u086f\u0871\u0005d\u0000\u0000\u0870"+
		"\u086f\u0001\u0000\u0000\u0000\u0870\u0871\u0001\u0000\u0000\u0000\u0871"+
		"\u0872\u0001\u0000\u0000\u0000\u0872\u0873\u0005\u01bb\u0000\u0000\u0873"+
		"\u0874\u0005\u0482\u0000\u0000\u0874\u0875\u0003\u02ba\u015d\u0000\u0875"+
		"\u0876\u0005\u0483\u0000\u0000\u0876\u089d\u0001\u0000\u0000\u0000\u0877"+
		"\u0879\u0005d\u0000\u0000\u0878\u0877\u0001\u0000\u0000\u0000\u0878\u0879"+
		"\u0001\u0000\u0000\u0000\u0879\u087a\u0001\u0000\u0000\u0000\u087a\u087e"+
		"\u0005[\u0000\u0000\u087b\u087c\u0005\u0150\u0000\u0000\u087c\u087d\u0005"+
		"\u0479\u0000\u0000\u087d\u087f\u0007#\u0000\u0000\u087e\u087b\u0001\u0000"+
		"\u0000\u0000\u087e\u087f\u0001\u0000\u0000\u0000\u087f\u0880\u0001\u0000"+
		"\u0000\u0000\u0880\u0881\u0005\u0482\u0000\u0000\u0881\u0882\u0003\u0272"+
		"\u0139\u0000\u0882\u0883\u0005\u0483\u0000\u0000\u0883\u089d\u0001\u0000"+
		"\u0000\u0000\u0884\u088e\u0005\u0086\u0000\u0000\u0885\u0886\u0005\u0482"+
		"\u0000\u0000\u0886\u0887\u0003\u02ba\u015d\u0000\u0887\u0888\u0005\u0483"+
		"\u0000\u0000\u0888\u088f\u0001\u0000\u0000\u0000\u0889\u088a\u0005\u016d"+
		"\u0000\u0000\u088a\u088b\u0005\u0482\u0000\u0000\u088b\u088c\u0003\u0272"+
		"\u0139\u0000\u088c\u088d\u0005\u0483\u0000\u0000\u088d\u088f\u0001\u0000"+
		"\u0000\u0000\u088e\u0885\u0001\u0000\u0000\u0000\u088e\u0889\u0001\u0000"+
		"\u0000\u0000\u088f\u089d\u0001\u0000\u0000\u0000\u0890\u089a\u0005\u01d9"+
		"\u0000\u0000\u0891\u0892\u0005\u0482\u0000\u0000\u0892\u0893\u0003\u02ba"+
		"\u015d\u0000\u0893\u0894\u0005\u0483\u0000\u0000\u0894\u089b\u0001\u0000"+
		"\u0000\u0000\u0895\u0896\u0005\u016d\u0000\u0000\u0896\u0897\u0005\u0482"+
		"\u0000\u0000\u0897\u0898\u0003\u0272\u0139\u0000\u0898\u0899\u0005\u0483"+
		"\u0000\u0000\u0899\u089b\u0001\u0000\u0000\u0000\u089a\u0891\u0001\u0000"+
		"\u0000\u0000\u089a\u0895\u0001\u0000\u0000\u0000\u089b\u089d\u0001\u0000"+
		"\u0000\u0000\u089c\u0870\u0001\u0000\u0000\u0000\u089c\u0878\u0001\u0000"+
		"\u0000\u0000\u089c\u0884\u0001\u0000\u0000\u0000\u089c\u0890\u0001\u0000"+
		"\u0000\u0000\u089dy\u0001\u0000\u0000\u0000\u089e\u08a0\u0005d\u0000\u0000"+
		"\u089f\u089e\u0001\u0000\u0000\u0000\u089f\u08a0\u0001\u0000\u0000\u0000"+
		"\u08a0\u08a1\u0001\u0000\u0000\u0000\u08a1\u08a2\u0005\u01bb\u0000\u0000"+
		"\u08a2\u08a3\u0005\u0482\u0000\u0000\u08a3\u08a4\u0003\u02ba\u015d\u0000"+
		"\u08a4\u08a5\u0005\u0483\u0000\u0000\u08a5\u08b4\u0001\u0000\u0000\u0000"+
		"\u08a6\u08a8\u0005d\u0000\u0000\u08a7\u08a6\u0001\u0000\u0000\u0000\u08a7"+
		"\u08a8\u0001\u0000\u0000\u0000\u08a8\u08a9\u0001\u0000\u0000\u0000\u08a9"+
		"\u08ad\u0005[\u0000\u0000\u08aa\u08ab\u0005\u0150\u0000\u0000\u08ab\u08ac"+
		"\u0005\u0479\u0000\u0000\u08ac\u08ae\u0007#\u0000\u0000\u08ad\u08aa\u0001"+
		"\u0000\u0000\u0000\u08ad\u08ae\u0001\u0000\u0000\u0000\u08ae\u08af\u0001"+
		"\u0000\u0000\u0000\u08af\u08b0\u0005\u0482\u0000\u0000\u08b0\u08b1\u0003"+
		"\u0272\u0139\u0000\u08b1\u08b2\u0005\u0483\u0000\u0000\u08b2\u08b4\u0001"+
		"\u0000\u0000\u0000\u08b3\u089f\u0001\u0000\u0000\u0000\u08b3\u08a7\u0001"+
		"\u0000\u0000\u0000\u08b4{\u0001\u0000\u0000\u0000\u08b5\u08b6\u0005\u0081"+
		"\u0000\u0000\u08b6\u08b7\u0003\u0250\u0128\u0000\u08b7\u08b8\u0005\u00bc"+
		"\u0000\u0000\u08b8\u08b9\u0005\u01d7\u0000\u0000\u08b9\u08ba\u0005\u028e"+
		"\u0000\u0000\u08ba\u08bb\u0005\u0482\u0000\u0000\u08bb\u08c0\u0003~?\u0000"+
		"\u08bc\u08bd\u0005\u0484\u0000\u0000\u08bd\u08bf\u0003~?\u0000\u08be\u08bc"+
		"\u0001\u0000\u0000\u0000\u08bf\u08c2\u0001\u0000\u0000\u0000\u08c0\u08be"+
		"\u0001\u0000\u0000\u0000\u08c0\u08c1\u0001\u0000\u0000\u0000\u08c1\u08c3"+
		"\u0001\u0000\u0000\u0000\u08c2\u08c0\u0001\u0000\u0000\u0000\u08c3\u08c7"+
		"\u0005\u0483\u0000\u0000\u08c4\u08c6\u0003\u0084B\u0000\u08c5\u08c4\u0001"+
		"\u0000\u0000\u0000\u08c6\u08c9\u0001\u0000\u0000\u0000\u08c7\u08c5\u0001"+
		"\u0000\u0000\u0000\u08c7\u08c8\u0001\u0000\u0000\u0000\u08c8\u08d5\u0001"+
		"\u0000\u0000\u0000\u08c9\u08c7\u0001\u0000\u0000\u0000\u08ca\u08cb\u0005"+
		"\u0482\u0000\u0000\u08cb\u08d0\u0003\u0082A\u0000\u08cc\u08cd\u0005\u0484"+
		"\u0000\u0000\u08cd\u08cf\u0003\u0082A\u0000\u08ce\u08cc\u0001\u0000\u0000"+
		"\u0000\u08cf\u08d2\u0001\u0000\u0000\u0000\u08d0\u08ce\u0001\u0000\u0000"+
		"\u0000\u08d0\u08d1\u0001\u0000\u0000\u0000\u08d1\u08d3\u0001\u0000\u0000"+
		"\u0000\u08d2\u08d0\u0001\u0000\u0000\u0000\u08d3\u08d4\u0005\u0483\u0000"+
		"\u0000\u08d4\u08d6\u0001\u0000\u0000\u0000\u08d5\u08ca\u0001\u0000\u0000"+
		"\u0000\u08d5\u08d6\u0001\u0000\u0000\u0000\u08d6\u0948\u0001\u0000\u0000"+
		"\u0000\u08d7\u08d8\u0005\u0081\u0000\u0000\u08d8\u08d9\u0003\u0250\u0128"+
		"\u0000\u08d9\u08da\u0005\u00bc\u0000\u0000\u08da\u08db\u0005\u01d7\u0000"+
		"\u0000\u08db\u08dc\u0005\u028e\u0000\u0000\u08dc\u08e0\u0003~?\u0000\u08dd"+
		"\u08df\u0003\u0084B\u0000\u08de\u08dd\u0001\u0000\u0000\u0000\u08df\u08e2"+
		"\u0001\u0000\u0000\u0000\u08e0\u08de\u0001\u0000\u0000\u0000\u08e0\u08e1"+
		"\u0001\u0000\u0000\u0000\u08e1\u08ee\u0001\u0000\u0000\u0000\u08e2\u08e0"+
		"\u0001\u0000\u0000\u0000\u08e3\u08e4\u0005\u0482\u0000\u0000\u08e4\u08e9"+
		"\u0003\u0082A\u0000\u08e5\u08e6\u0005\u0484\u0000\u0000\u08e6\u08e8\u0003"+
		"\u0082A\u0000\u08e7\u08e5\u0001\u0000\u0000\u0000\u08e8\u08eb\u0001\u0000"+
		"\u0000\u0000\u08e9\u08e7\u0001\u0000\u0000\u0000\u08e9\u08ea\u0001\u0000"+
		"\u0000\u0000\u08ea\u08ec\u0001\u0000\u0000\u0000\u08eb\u08e9\u0001\u0000"+
		"\u0000\u0000\u08ec\u08ed\u0005\u0483\u0000\u0000\u08ed\u08ef\u0001\u0000"+
		"\u0000\u0000\u08ee\u08e3\u0001\u0000\u0000\u0000\u08ee\u08ef\u0001\u0000"+
		"\u0000\u0000\u08ef\u0948\u0001\u0000\u0000\u0000\u08f0\u08f1\u0005\u0081"+
		"\u0000\u0000\u08f1\u08f2\u0003\u0250\u0128\u0000\u08f2\u08f3\u0005\u00bc"+
		"\u0000\u0000\u08f3\u08f4\u0005P\u0000\u0000\u08f4\u08f5\u0005\u0482\u0000"+
		"\u0000\u08f5\u08fa\u0003~?\u0000\u08f6\u08f7\u0005\u0484\u0000\u0000\u08f7"+
		"\u08f9\u0003~?\u0000\u08f8\u08f6\u0001\u0000\u0000\u0000\u08f9\u08fc\u0001"+
		"\u0000\u0000\u0000\u08fa\u08f8\u0001\u0000\u0000\u0000\u08fa\u08fb\u0001"+
		"\u0000\u0000\u0000\u08fb\u08fd\u0001\u0000\u0000\u0000\u08fc\u08fa\u0001"+
		"\u0000\u0000\u0000\u08fd\u0901\u0005\u0483\u0000\u0000\u08fe\u0900\u0003"+
		"\u0084B\u0000\u08ff\u08fe\u0001\u0000\u0000\u0000\u0900\u0903\u0001\u0000"+
		"\u0000\u0000\u0901\u08ff\u0001\u0000\u0000\u0000\u0901\u0902\u0001\u0000"+
		"\u0000\u0000\u0902\u090f\u0001\u0000\u0000\u0000\u0903\u0901\u0001\u0000"+
		"\u0000\u0000\u0904\u0905\u0005\u0482\u0000\u0000\u0905\u090a\u0003\u0082"+
		"A\u0000\u0906\u0907\u0005\u0484\u0000\u0000\u0907\u0909\u0003\u0082A\u0000"+
		"\u0908\u0906\u0001\u0000\u0000\u0000\u0909\u090c\u0001\u0000\u0000\u0000"+
		"\u090a\u0908\u0001\u0000\u0000\u0000\u090a\u090b\u0001\u0000\u0000\u0000"+
		"\u090b\u090d\u0001\u0000\u0000\u0000\u090c\u090a\u0001\u0000\u0000\u0000"+
		"\u090d\u090e\u0005\u0483\u0000\u0000\u090e\u0910\u0001\u0000\u0000\u0000"+
		"\u090f\u0904\u0001\u0000\u0000\u0000\u090f\u0910\u0001\u0000\u0000\u0000"+
		"\u0910\u0948\u0001\u0000\u0000\u0000\u0911\u0912\u0005\u0081\u0000\u0000"+
		"\u0912\u0913\u0003\u0250\u0128\u0000\u0913\u0914\u0005\u00bc\u0000\u0000"+
		"\u0914\u0915\u0005P\u0000\u0000\u0915\u0916\u0005\u0482\u0000\u0000\u0916"+
		"\u091b\u0003\u0080@\u0000\u0917\u0918\u0005\u0484\u0000\u0000\u0918\u091a"+
		"\u0003\u0080@\u0000\u0919\u0917\u0001\u0000\u0000\u0000\u091a\u091d\u0001"+
		"\u0000\u0000\u0000\u091b\u0919\u0001\u0000\u0000\u0000\u091b\u091c\u0001"+
		"\u0000\u0000\u0000\u091c\u091e\u0001\u0000\u0000\u0000\u091d\u091b\u0001"+
		"\u0000\u0000\u0000\u091e\u0922\u0005\u0483\u0000\u0000\u091f\u0921\u0003"+
		"\u0084B\u0000\u0920\u091f\u0001\u0000\u0000\u0000\u0921\u0924\u0001\u0000"+
		"\u0000\u0000\u0922\u0920\u0001\u0000\u0000\u0000\u0922\u0923\u0001\u0000"+
		"\u0000\u0000\u0923\u0930\u0001\u0000\u0000\u0000\u0924\u0922\u0001\u0000"+
		"\u0000\u0000\u0925\u0926\u0005\u0482\u0000\u0000\u0926\u092b\u0003\u0082"+
		"A\u0000\u0927\u0928\u0005\u0484\u0000\u0000\u0928\u092a\u0003\u0082A\u0000"+
		"\u0929\u0927\u0001\u0000\u0000\u0000\u092a\u092d\u0001\u0000\u0000\u0000"+
		"\u092b\u0929\u0001\u0000\u0000\u0000\u092b\u092c\u0001\u0000\u0000\u0000"+
		"\u092c\u092e\u0001\u0000\u0000\u0000\u092d\u092b\u0001\u0000\u0000\u0000"+
		"\u092e\u092f\u0005\u0483\u0000\u0000\u092f\u0931\u0001\u0000\u0000\u0000"+
		"\u0930\u0925\u0001\u0000\u0000\u0000\u0930\u0931\u0001\u0000\u0000\u0000"+
		"\u0931\u0948\u0001\u0000\u0000\u0000\u0932\u0933\u0005\u0081\u0000\u0000"+
		"\u0933\u0937\u0003\u0250\u0128\u0000\u0934\u0936\u0003\u0084B\u0000\u0935"+
		"\u0934\u0001\u0000\u0000\u0000\u0936\u0939\u0001\u0000\u0000\u0000\u0937"+
		"\u0935\u0001\u0000\u0000\u0000\u0937\u0938\u0001\u0000\u0000\u0000\u0938"+
		"\u0945\u0001\u0000\u0000\u0000\u0939\u0937\u0001\u0000\u0000\u0000\u093a"+
		"\u093b\u0005\u0482\u0000\u0000\u093b\u0940\u0003\u0082A\u0000\u093c\u093d"+
		"\u0005\u0484\u0000\u0000\u093d\u093f\u0003\u0082A\u0000\u093e\u093c\u0001"+
		"\u0000\u0000\u0000\u093f\u0942\u0001\u0000\u0000\u0000\u0940\u093e\u0001"+
		"\u0000\u0000\u0000\u0940\u0941\u0001\u0000\u0000\u0000\u0941\u0943\u0001"+
		"\u0000\u0000\u0000\u0942\u0940\u0001\u0000\u0000\u0000\u0943\u0944\u0005"+
		"\u0483\u0000\u0000\u0944\u0946\u0001\u0000\u0000\u0000\u0945\u093a\u0001"+
		"\u0000\u0000\u0000\u0945\u0946\u0001\u0000\u0000\u0000\u0946\u0948\u0001"+
		"\u0000\u0000\u0000\u0947\u08b5\u0001\u0000\u0000\u0000\u0947\u08d7\u0001"+
		"\u0000\u0000\u0000\u0947\u08f0\u0001\u0000\u0000\u0000\u0947\u0911\u0001"+
		"\u0000\u0000\u0000\u0947\u0932\u0001\u0000\u0000\u0000\u0948}\u0001\u0000"+
		"\u0000\u0000\u0949\u094d\u0003\u0262\u0131\u0000\u094a\u094d\u0003\u02ba"+
		"\u015d\u0000\u094b\u094d\u0005n\u0000\u0000\u094c\u0949\u0001\u0000\u0000"+
		"\u0000\u094c\u094a\u0001\u0000\u0000\u0000\u094c\u094b\u0001\u0000\u0000"+
		"\u0000\u094d\u007f\u0001\u0000\u0000\u0000\u094e\u094f\u0005\u0482\u0000"+
		"\u0000\u094f\u0952\u0003~?\u0000\u0950\u0951\u0005\u0484\u0000\u0000\u0951"+
		"\u0953\u0003~?\u0000\u0952\u0950\u0001\u0000\u0000\u0000\u0953\u0954\u0001"+
		"\u0000\u0000\u0000\u0954\u0952\u0001\u0000\u0000\u0000\u0954\u0955\u0001"+
		"\u0000\u0000\u0000\u0955\u0956\u0001\u0000\u0000\u0000\u0956\u0957\u0005"+
		"\u0483\u0000\u0000\u0957\u0081\u0001\u0000\u0000\u0000\u0958\u0959\u0005"+
		"\u0284\u0000\u0000\u0959\u095d\u0003\u0250\u0128\u0000\u095a\u095c\u0003"+
		"\u0084B\u0000\u095b\u095a\u0001\u0000\u0000\u0000\u095c\u095f\u0001\u0000"+
		"\u0000\u0000\u095d\u095b\u0001\u0000\u0000\u0000\u095d\u095e\u0001\u0000"+
		"\u0000\u0000\u095e\u0083\u0001\u0000\u0000\u0000\u095f\u095d\u0001\u0000"+
		"\u0000\u0000\u0960\u0962\u0005+\u0000\u0000\u0961\u0960\u0001\u0000\u0000"+
		"\u0000\u0961\u0962\u0001\u0000\u0000\u0000\u0962\u0964\u0001\u0000\u0000"+
		"\u0000\u0963\u0965\u0005\u027f\u0000\u0000\u0964\u0963\u0001\u0000\u0000"+
		"\u0000\u0964\u0965\u0001\u0000\u0000\u0000\u0965\u0966\u0001\u0000\u0000"+
		"\u0000\u0966\u0968\u0005\u0199\u0000\u0000\u0967\u0969\u0005\u0479\u0000"+
		"\u0000\u0968\u0967\u0001\u0000\u0000\u0000\u0968\u0969\u0001\u0000\u0000"+
		"\u0000\u0969\u096a\u0001\u0000\u0000\u0000\u096a\u0991\u0003\u0242\u0121"+
		"\u0000\u096b\u096d\u0005\u0170\u0000\u0000\u096c\u096e\u0005\u0479\u0000"+
		"\u0000\u096d\u096c\u0001\u0000\u0000\u0000\u096d\u096e\u0001\u0000\u0000"+
		"\u0000\u096e\u096f\u0001\u0000\u0000\u0000\u096f\u0991\u0005\u0491\u0000"+
		"\u0000\u0970\u0971\u0005\u0184\u0000\u0000\u0971\u0973\u0005\u018b\u0000"+
		"\u0000\u0972\u0974\u0005\u0479\u0000\u0000\u0973\u0972\u0001\u0000\u0000"+
		"\u0000\u0973\u0974\u0001\u0000\u0000\u0000\u0974\u0975\u0001\u0000\u0000"+
		"\u0000\u0975\u0991\u0005\u0491\u0000\u0000\u0976\u0977\u0005Q\u0000\u0000"+
		"\u0977\u0979\u0005\u018b\u0000\u0000\u0978\u097a\u0005\u0479\u0000\u0000"+
		"\u0979\u0978\u0001\u0000\u0000\u0000\u0979\u097a\u0001\u0000\u0000\u0000"+
		"\u097a\u097b\u0001\u0000\u0000\u0000\u097b\u0991\u0005\u0491\u0000\u0000"+
		"\u097c\u097e\u0005\u01f5\u0000\u0000\u097d\u097f\u0005\u0479\u0000\u0000"+
		"\u097e\u097d\u0001\u0000\u0000\u0000\u097e\u097f\u0001\u0000\u0000\u0000"+
		"\u097f\u0980\u0001\u0000\u0000\u0000\u0980\u0991\u0003\u0256\u012b\u0000"+
		"\u0981\u0983\u0005\u01ff\u0000\u0000\u0982\u0984\u0005\u0479\u0000\u0000"+
		"\u0983\u0982\u0001\u0000\u0000\u0000\u0983\u0984\u0001\u0000\u0000\u0000"+
		"\u0984\u0985\u0001\u0000\u0000\u0000\u0985\u0991\u0003\u0256\u012b\u0000"+
		"\u0986\u0988\u0005\u028a\u0000\u0000\u0987\u0989\u0005\u0479\u0000\u0000"+
		"\u0988\u0987\u0001\u0000\u0000\u0000\u0988\u0989\u0001\u0000\u0000\u0000"+
		"\u0989\u098a\u0001\u0000\u0000\u0000\u098a\u0991\u0003\u0250\u0128\u0000"+
		"\u098b\u098d\u0005\u0211\u0000\u0000\u098c\u098e\u0005\u0479\u0000\u0000"+
		"\u098d\u098c\u0001\u0000\u0000\u0000\u098d\u098e\u0001\u0000\u0000\u0000"+
		"\u098e\u098f\u0001\u0000\u0000\u0000\u098f\u0991\u0003\u0250\u0128\u0000"+
		"\u0990\u0961\u0001\u0000\u0000\u0000\u0990\u096b\u0001\u0000\u0000\u0000"+
		"\u0990\u0970\u0001\u0000\u0000\u0000\u0990\u0976\u0001\u0000\u0000\u0000"+
		"\u0990\u097c\u0001\u0000\u0000\u0000\u0990\u0981\u0001\u0000\u0000\u0000"+
		"\u0990\u0986\u0001\u0000\u0000\u0000\u0990\u098b\u0001\u0000\u0000\u0000"+
		"\u0991\u0085\u0001\u0000\u0000\u0000\u0992\u0993\u0005\u0007\u0000\u0000"+
		"\u0993\u0995\u0007\u0000\u0000\u0000\u0994\u0996\u0003\u0250\u0128\u0000"+
		"\u0995\u0994\u0001\u0000\u0000\u0000\u0995\u0996\u0001\u0000\u0000\u0000"+
		"\u0996\u0998\u0001\u0000\u0000\u0000\u0997\u0999\u0003@ \u0000\u0998\u0997"+
		"\u0001\u0000\u0000\u0000\u0999\u099a\u0001\u0000\u0000\u0000\u099a\u0998"+
		"\u0001\u0000\u0000\u0000\u099a\u099b\u0001\u0000\u0000\u0000\u099b\u09a5"+
		"\u0001\u0000\u0000\u0000\u099c\u099d\u0005\u0007\u0000\u0000\u099d\u099e"+
		"\u0007\u0000\u0000\u0000\u099e\u099f\u0003\u0250\u0128\u0000\u099f\u09a0"+
		"\u0005\u029c\u0000\u0000\u09a0\u09a1\u0005\u0184\u0000\u0000\u09a1\u09a2"+
		"\u0005\u018b\u0000\u0000\u09a2\u09a3\u0005\u0205\u0000\u0000\u09a3\u09a5"+
		"\u0001\u0000\u0000\u0000\u09a4\u0992\u0001\u0000\u0000\u0000\u09a4\u099c"+
		"\u0001\u0000\u0000\u0000\u09a5\u0087\u0001\u0000\u0000\u0000\u09a6\u09a8"+
		"\u0005\u0007\u0000\u0000\u09a7\u09a9\u0003F#\u0000\u09a8\u09a7\u0001\u0000"+
		"\u0000\u0000\u09a8\u09a9\u0001\u0000\u0000\u0000\u09a9\u09aa\u0001\u0000"+
		"\u0000\u0000\u09aa\u09ab\u0005\u019f\u0000\u0000\u09ab\u09af\u0003\u022c"+
		"\u0116\u0000\u09ac\u09ad\u0005v\u0000\u0000\u09ad\u09ae\u0005\u025f\u0000"+
		"\u0000\u09ae\u09b0\u0003H$\u0000\u09af\u09ac\u0001\u0000\u0000\u0000\u09af"+
		"\u09b0\u0001\u0000\u0000\u0000\u09b0\u09b7\u0001\u0000\u0000\u0000\u09b1"+
		"\u09b2\u0005v\u0000\u0000\u09b2\u09b4\u0005\u0173\u0000\u0000\u09b3\u09b5"+
		"\u0005r\u0000\u0000\u09b4\u09b3\u0001\u0000\u0000\u0000\u09b4\u09b5\u0001"+
		"\u0000\u0000\u0000\u09b5\u09b6\u0001\u0000\u0000\u0000\u09b6\u09b8\u0005"+
		"\u0232\u0000\u0000\u09b7\u09b1\u0001\u0000\u0000\u0000\u09b7\u09b8\u0001"+
		"\u0000\u0000\u0000\u09b8\u09bc\u0001\u0000\u0000\u0000\u09b9\u09ba\u0005"+
		"\u008c\u0000\u0000\u09ba\u09bb\u0005\u00af\u0000\u0000\u09bb\u09bd\u0003"+
		"\u022c\u0116\u0000\u09bc\u09b9\u0001\u0000\u0000\u0000\u09bc\u09bd\u0001"+
		"\u0000\u0000\u0000\u09bd\u09bf\u0001\u0000\u0000\u0000\u09be\u09c0\u0003"+
		"P(\u0000\u09bf\u09be\u0001\u0000\u0000\u0000\u09bf\u09c0\u0001\u0000\u0000"+
		"\u0000\u09c0\u09c3\u0001\u0000\u0000\u0000\u09c1\u09c2\u0005\u0170\u0000"+
		"\u0000\u09c2\u09c4\u0005\u0491\u0000\u0000\u09c3\u09c1\u0001\u0000\u0000"+
		"\u0000\u09c3\u09c4\u0001\u0000\u0000\u0000\u09c4\u09c7\u0001\u0000\u0000"+
		"\u0000\u09c5\u09c6\u0005\u018f\u0000\u0000\u09c6\u09c8\u0003\u018c\u00c6"+
		"\u0000\u09c7\u09c5\u0001\u0000\u0000\u0000\u09c7\u09c8\u0001\u0000\u0000"+
		"\u0000\u09c8\u0089\u0001\u0000\u0000\u0000\u09c9\u09ca\u0005\u0007\u0000"+
		"\u0000\u09ca\u09cb\u0005\u01b5\u0000\u0000\u09cb\u09cf\u0003\u022c\u0116"+
		"\u0000\u09cc\u09ce\u0003Z-\u0000\u09cd\u09cc\u0001\u0000\u0000\u0000\u09ce"+
		"\u09d1\u0001\u0000\u0000\u0000\u09cf\u09cd\u0001\u0000\u0000\u0000\u09cf"+
		"\u09d0\u0001\u0000\u0000\u0000\u09d0\u008b\u0001\u0000\u0000\u0000\u09d1"+
		"\u09cf\u0001\u0000\u0000\u0000\u09d2\u09d3\u0005\u0007\u0000\u0000\u09d3"+
		"\u09d4\u0005\u01c9\u0000\u0000\u09d4\u09d5\u0005\u0259\u0000\u0000\u09d5"+
		"\u09d6\u0005\u031e\u0000\u0000\u09d6\u09d7\u0005\u01de\u0000\u0000\u09d7"+
		"\u09d8\u0005[\u0000\u0000\u09d8\u008d\u0001\u0000\u0000\u0000\u09d9\u09da"+
		"\u0005\u0007\u0000\u0000\u09da\u09db\u0005\u01dc\u0000\u0000\u09db\u09dc"+
		"\u0005I\u0000\u0000\u09dc\u09dd\u0003\u0250\u0128\u0000\u09dd\u09de\u0005"+
		"\u0005\u0000\u0000\u09de\u09df\u0005\u0297\u0000\u0000\u09df\u09e5\u0005"+
		"\u0491\u0000\u0000\u09e0\u09e2\u0005\u01c5\u0000\u0000\u09e1\u09e3\u0005"+
		"\u0479\u0000\u0000\u09e2\u09e1\u0001\u0000\u0000\u0000\u09e2\u09e3\u0001"+
		"\u0000\u0000\u0000\u09e3\u09e4\u0001\u0000\u0000\u0000\u09e4\u09e6\u0003"+
		"\u0258\u012c\u0000\u09e5\u09e0\u0001\u0000\u0000\u0000\u09e5\u09e6\u0001"+
		"\u0000\u0000\u0000\u09e6\u09e8\u0001\u0000\u0000\u0000\u09e7\u09e9\u0005"+
		"\u02a6\u0000\u0000\u09e8\u09e7\u0001\u0000\u0000\u0000\u09e8\u09e9\u0001"+
		"\u0000\u0000\u0000\u09e9\u09ea\u0001\u0000\u0000\u0000\u09ea\u09ec\u0005"+
		"\u0199\u0000\u0000\u09eb\u09ed\u0005\u0479\u0000\u0000\u09ec\u09eb\u0001"+
		"\u0000\u0000\u0000\u09ec\u09ed\u0001\u0000\u0000\u0000\u09ed\u09ee\u0001"+
		"\u0000\u0000\u0000\u09ee\u09ef\u0003\u0242\u0121\u0000\u09ef\u008f\u0001"+
		"\u0000\u0000\u0000\u09f0\u09f1\u0005\u0007\u0000\u0000\u09f1\u09f2\u0005"+
		"\u0084\u0000\u0000\u09f2\u09f6\u0003\u022c\u0116\u0000\u09f3\u09f5\u0003"+
		"Z-\u0000\u09f4\u09f3\u0001\u0000\u0000\u0000\u09f5\u09f8\u0001\u0000\u0000"+
		"\u0000\u09f6\u09f4\u0001\u0000\u0000\u0000\u09f6\u09f7\u0001\u0000\u0000"+
		"\u0000\u09f7\u0091\u0001\u0000\u0000\u0000\u09f8\u09f6\u0001\u0000\u0000"+
		"\u0000\u09f9\u09fa\u0005\u0007\u0000\u0000\u09fa\u09fb\u0005\u0262\u0000"+
		"\u0000\u09fb\u09fc\u0003\u0250\u0128\u0000\u09fc\u09fd\u0005\u021e\u0000"+
		"\u0000\u09fd\u09fe\u0005\u0482\u0000\u0000\u09fe\u0a03\u0003\\.\u0000"+
		"\u09ff\u0a00\u0005\u0484\u0000\u0000\u0a00\u0a02\u0003\\.\u0000\u0a01"+
		"\u09ff\u0001\u0000\u0000\u0000\u0a02\u0a05\u0001\u0000\u0000\u0000\u0a03"+
		"\u0a01\u0001\u0000\u0000\u0000\u0a03\u0a04\u0001\u0000\u0000\u0000\u0a04"+
		"\u0a06\u0001\u0000\u0000\u0000\u0a05\u0a03\u0001\u0000\u0000\u0000\u0a06"+
		"\u0a07\u0005\u0483\u0000\u0000\u0a07\u0093\u0001\u0000\u0000\u0000\u0a08"+
		"\u0a0a\u0005\u0007\u0000\u0000\u0a09\u0a0b\u0007\u0001\u0000\u0000\u0a0a"+
		"\u0a09\u0001\u0000\u0000\u0000\u0a0a\u0a0b\u0001\u0000\u0000\u0000\u0a0b"+
		"\u0a0d\u0001\u0000\u0000\u0000\u0a0c\u0a0e\u0005N\u0000\u0000\u0a0d\u0a0c"+
		"\u0001\u0000\u0000\u0000\u0a0d\u0a0e\u0001\u0000\u0000\u0000\u0a0e\u0a0f"+
		"\u0001\u0000\u0000\u0000\u0a0f\u0a11\u0005\u00ac\u0000\u0000\u0a10\u0a12"+
		"\u0003\u0288\u0144\u0000\u0a11\u0a10\u0001\u0000\u0000\u0000\u0a11\u0a12"+
		"\u0001\u0000\u0000\u0000\u0a12\u0a13\u0001\u0000\u0000\u0000\u0a13\u0a15"+
		"\u0003\u022e\u0117\u0000\u0a14\u0a16\u0003\u028e\u0147\u0000\u0a15\u0a14"+
		"\u0001\u0000\u0000\u0000\u0a15\u0a16\u0001\u0000\u0000\u0000\u0a16\u0a1f"+
		"\u0001\u0000\u0000\u0000\u0a17\u0a1c\u0003\u009cN\u0000\u0a18\u0a19\u0005"+
		"\u0484\u0000\u0000\u0a19\u0a1b\u0003\u009cN\u0000\u0a1a\u0a18\u0001\u0000"+
		"\u0000\u0000\u0a1b\u0a1e\u0001\u0000\u0000\u0000\u0a1c\u0a1a\u0001\u0000"+
		"\u0000\u0000\u0a1c\u0a1d\u0001\u0000\u0000\u0000\u0a1d\u0a20\u0001\u0000"+
		"\u0000\u0000\u0a1e\u0a1c\u0001\u0000\u0000\u0000\u0a1f\u0a17\u0001\u0000"+
		"\u0000\u0000\u0a1f\u0a20\u0001\u0000\u0000\u0000\u0a20\u0a22\u0001\u0000"+
		"\u0000\u0000\u0a21\u0a23\u0003v;\u0000\u0a22\u0a21\u0001\u0000\u0000\u0000"+
		"\u0a22\u0a23\u0001\u0000\u0000\u0000\u0a23\u0095\u0001\u0000\u0000\u0000"+
		"\u0a24\u0a25\u0005\u0007\u0000\u0000\u0a25\u0a26\u0005\u028a\u0000\u0000"+
		"\u0a26\u0a27\u0003\u0250\u0128\u0000\u0a27\u0a28\u0007$\u0000\u0000\u0a28"+
		"\u0a29\u0005\u0185\u0000\u0000\u0a29\u0a2d\u0005\u0491\u0000\u0000\u0a2a"+
		"\u0a2b\u0005\u01c5\u0000\u0000\u0a2b\u0a2c\u0005\u0479\u0000\u0000\u0a2c"+
		"\u0a2e\u0003\u0258\u012c\u0000\u0a2d\u0a2a\u0001\u0000\u0000\u0000\u0a2d"+
		"\u0a2e\u0001\u0000\u0000\u0000\u0a2e\u0a30\u0001\u0000\u0000\u0000\u0a2f"+
		"\u0a31\u0005\u02a6\u0000\u0000\u0a30\u0a2f\u0001\u0000\u0000\u0000\u0a30"+
		"\u0a31\u0001\u0000\u0000\u0000\u0a31\u0a32\u0001\u0000\u0000\u0000\u0a32"+
		"\u0a34\u0005\u0199\u0000\u0000\u0a33\u0a35\u0005\u0479\u0000\u0000\u0a34"+
		"\u0a33\u0001\u0000\u0000\u0000\u0a34\u0a35\u0001\u0000\u0000\u0000\u0a35"+
		"\u0a36\u0001\u0000\u0000\u0000\u0a36\u0a37\u0003\u0242\u0121\u0000\u0a37"+
		"\u0097\u0001\u0000\u0000\u0000\u0a38\u0a3c\u0005\u0007\u0000\u0000\u0a39"+
		"\u0a3a\u0005\u0150\u0000\u0000\u0a3a\u0a3b\u0005\u0479\u0000\u0000\u0a3b"+
		"\u0a3d\u0007\n\u0000\u0000\u0a3c\u0a39\u0001\u0000\u0000\u0000\u0a3c\u0a3d"+
		"\u0001\u0000\u0000\u0000\u0a3d\u0a3f\u0001\u0000\u0000\u0000\u0a3e\u0a40"+
		"\u0003F#\u0000\u0a3f\u0a3e\u0001\u0000\u0000\u0000\u0a3f\u0a40\u0001\u0000"+
		"\u0000\u0000\u0a40\u0a44\u0001\u0000\u0000\u0000\u0a41\u0a42\u0005\u00a0"+
		"\u0000\u0000\u0a42\u0a43\u0005\u0260\u0000\u0000\u0a43\u0a45\u0007\u000b"+
		"\u0000\u0000\u0a44\u0a41\u0001\u0000\u0000\u0000\u0a44\u0a45\u0001\u0000"+
		"\u0000\u0000\u0a45\u0a46\u0001\u0000\u0000\u0000\u0a46\u0a47\u0005\u02a3"+
		"\u0000\u0000\u0a47\u0a4c\u0003\u022c\u0116\u0000\u0a48\u0a49\u0005\u0482"+
		"\u0000\u0000\u0a49\u0a4a\u0003\u0272\u0139\u0000\u0a4a\u0a4b\u0005\u0483"+
		"\u0000\u0000\u0a4b\u0a4d\u0001\u0000\u0000\u0000\u0a4c\u0a48\u0001\u0000"+
		"\u0000\u0000\u0a4c\u0a4d\u0001\u0000\u0000\u0000\u0a4d\u0a4e\u0001\u0000"+
		"\u0000\u0000\u0a4e\u0a4f\u0005\f\u0000\u0000\u0a4f\u0a56\u0003\u00d2i"+
		"\u0000\u0a50\u0a52\u0005\u00c0\u0000\u0000\u0a51\u0a53\u0007\f\u0000\u0000"+
		"\u0a52\u0a51\u0001\u0000\u0000\u0000\u0a52\u0a53\u0001\u0000\u0000\u0000"+
		"\u0a53\u0a54\u0001\u0000\u0000\u0000\u0a54\u0a55\u0005\u001b\u0000\u0000"+
		"\u0a55\u0a57\u0005x\u0000\u0000\u0a56\u0a50\u0001\u0000\u0000\u0000\u0a56"+
		"\u0a57\u0001\u0000\u0000\u0000\u0a57\u0099\u0001\u0000\u0000\u0000\u0a58"+
		"\u0a59\u0005\u0007\u0000\u0000\u0a59\u0a5b\u0005\u0261\u0000\u0000\u0a5a"+
		"\u0a5c\u0003\u0288\u0144\u0000\u0a5b\u0a5a\u0001\u0000\u0000\u0000\u0a5b"+
		"\u0a5c\u0001\u0000\u0000\u0000\u0a5c\u0a5d\u0001\u0000\u0000\u0000\u0a5d"+
		"\u0a5f\u0003\u022c\u0116\u0000\u0a5e\u0a60\u0003>\u001f\u0000\u0a5f\u0a5e"+
		"\u0001\u0000\u0000\u0000\u0a60\u0a61\u0001\u0000\u0000\u0000\u0a61\u0a5f"+
		"\u0001\u0000\u0000\u0000\u0a61\u0a62\u0001\u0000\u0000\u0000\u0a62\u009b"+
		"\u0001\u0000\u0000\u0000\u0a63\u0a6a\u0003p8\u0000\u0a64\u0a66\u0005\u0484"+
		"\u0000\u0000\u0a65\u0a64\u0001\u0000\u0000\u0000\u0a65\u0a66\u0001\u0000"+
		"\u0000\u0000\u0a66\u0a67\u0001\u0000\u0000\u0000\u0a67\u0a69\u0003p8\u0000"+
		"\u0a68\u0a65\u0001\u0000\u0000\u0000\u0a69\u0a6c\u0001\u0000\u0000\u0000"+
		"\u0a6a\u0a68\u0001\u0000\u0000\u0000\u0a6a\u0a6b\u0001\u0000\u0000\u0000"+
		"\u0a6b\u0ba7\u0001\u0000\u0000\u0000\u0a6c\u0a6a\u0001\u0000\u0000\u0000"+
		"\u0a6d\u0a6f\u0005\u0005\u0000\u0000\u0a6e\u0a70\u0005\u001d\u0000\u0000"+
		"\u0a6f\u0a6e\u0001\u0000\u0000\u0000\u0a6f\u0a70\u0001\u0000\u0000\u0000"+
		"\u0a70\u0a72\u0001\u0000\u0000\u0000\u0a71\u0a73\u0003\u028a\u0145\u0000"+
		"\u0a72\u0a71\u0001\u0000\u0000\u0000\u0a72\u0a73\u0001\u0000\u0000\u0000"+
		"\u0a73\u0a74\u0001\u0000\u0000\u0000\u0a74\u0a75\u0003\u0250\u0128\u0000"+
		"\u0a75\u0a79\u0003b1\u0000\u0a76\u0a7a\u0005\u01ae\u0000\u0000\u0a77\u0a78"+
		"\u0005\u014e\u0000\u0000\u0a78\u0a7a\u0003\u0250\u0128\u0000\u0a79\u0a76"+
		"\u0001\u0000\u0000\u0000\u0a79\u0a77\u0001\u0000\u0000\u0000\u0a79\u0a7a"+
		"\u0001\u0000\u0000\u0000\u0a7a\u0ba7\u0001\u0000\u0000\u0000\u0a7b\u0a7d"+
		"\u0005\u0005\u0000\u0000\u0a7c\u0a7e\u0005\u001d\u0000\u0000\u0a7d\u0a7c"+
		"\u0001\u0000\u0000\u0000\u0a7d\u0a7e\u0001\u0000\u0000\u0000\u0a7e\u0a80"+
		"\u0001\u0000\u0000\u0000\u0a7f\u0a81\u0003\u028a\u0145\u0000\u0a80\u0a7f"+
		"\u0001\u0000\u0000\u0000\u0a80\u0a81\u0001\u0000\u0000\u0000\u0a81\u0a82"+
		"\u0001\u0000\u0000\u0000\u0a82\u0a83\u0005\u0482\u0000\u0000\u0a83\u0a84"+
		"\u0003\u0250\u0128\u0000\u0a84\u0a8b\u0003b1\u0000\u0a85\u0a86\u0005\u0484"+
		"\u0000\u0000\u0a86\u0a87\u0003\u0250\u0128\u0000\u0a87\u0a88\u0003b1\u0000"+
		"\u0a88\u0a8a\u0001\u0000\u0000\u0000\u0a89\u0a85\u0001\u0000\u0000\u0000"+
		"\u0a8a\u0a8d\u0001\u0000\u0000\u0000\u0a8b\u0a89\u0001\u0000\u0000\u0000"+
		"\u0a8b\u0a8c\u0001\u0000\u0000\u0000\u0a8c\u0a8e\u0001\u0000\u0000\u0000"+
		"\u0a8d\u0a8b\u0001\u0000\u0000\u0000\u0a8e\u0a8f\u0005\u0483\u0000\u0000"+
		"\u0a8f\u0ba7\u0001\u0000\u0000\u0000\u0a90\u0a91\u0005\u0005\u0000\u0000"+
		"\u0a91\u0a93\u0007\u0017\u0000\u0000\u0a92\u0a94\u0003\u028a\u0145\u0000"+
		"\u0a93\u0a92\u0001\u0000\u0000\u0000\u0a93\u0a94\u0001\u0000\u0000\u0000"+
		"\u0a94\u0a96\u0001\u0000\u0000\u0000\u0a95\u0a97\u0003\u0250\u0128\u0000"+
		"\u0a96\u0a95\u0001\u0000\u0000\u0000\u0a96\u0a97\u0001\u0000\u0000\u0000"+
		"\u0a97\u0a99\u0001\u0000\u0000\u0000\u0a98\u0a9a\u0003R)\u0000\u0a99\u0a98"+
		"\u0001\u0000\u0000\u0000\u0a99\u0a9a\u0001\u0000\u0000\u0000\u0a9a\u0a9b"+
		"\u0001\u0000\u0000\u0000\u0a9b\u0a9f\u0003\u0276\u013b\u0000\u0a9c\u0a9e"+
		"\u0003T*\u0000\u0a9d\u0a9c\u0001\u0000\u0000\u0000\u0a9e\u0aa1\u0001\u0000"+
		"\u0000\u0000\u0a9f\u0a9d\u0001\u0000\u0000\u0000\u0a9f\u0aa0\u0001\u0000"+
		"\u0000\u0000\u0aa0\u0ba7\u0001\u0000\u0000\u0000\u0aa1\u0a9f\u0001\u0000"+
		"\u0000\u0000\u0aa2\u0aa7\u0005\u0005\u0000\u0000\u0aa3\u0aa5\u0005\u001f"+
		"\u0000\u0000\u0aa4\u0aa6\u0003\u0250\u0128\u0000\u0aa5\u0aa4\u0001\u0000"+
		"\u0000\u0000\u0aa5\u0aa6\u0001\u0000\u0000\u0000\u0aa6\u0aa8\u0001\u0000"+
		"\u0000\u0000\u0aa7\u0aa3\u0001\u0000\u0000\u0000\u0aa7\u0aa8\u0001\u0000"+
		"\u0000\u0000\u0aa8\u0aa9\u0001\u0000\u0000\u0000\u0aa9\u0aaa\u0005\u0082"+
		"\u0000\u0000\u0aaa\u0aac\u0005[\u0000\u0000\u0aab\u0aad\u0003\u0250\u0128"+
		"\u0000\u0aac\u0aab\u0001\u0000\u0000\u0000\u0aac\u0aad\u0001\u0000\u0000"+
		"\u0000\u0aad\u0aaf\u0001\u0000\u0000\u0000\u0aae\u0ab0\u0003R)\u0000\u0aaf"+
		"\u0aae\u0001\u0000\u0000\u0000\u0aaf\u0ab0\u0001\u0000\u0000\u0000\u0ab0"+
		"\u0ab1\u0001\u0000\u0000\u0000\u0ab1\u0ab5\u0003\u0276\u013b\u0000\u0ab2"+
		"\u0ab4\u0003T*\u0000\u0ab3\u0ab2\u0001\u0000\u0000\u0000\u0ab4\u0ab7\u0001"+
		"\u0000\u0000\u0000\u0ab5\u0ab3\u0001\u0000\u0000\u0000\u0ab5\u0ab6\u0001"+
		"\u0000\u0000\u0000\u0ab6\u0ba7\u0001\u0000\u0000\u0000\u0ab7\u0ab5\u0001"+
		"\u0000\u0000\u0000\u0ab8\u0abd\u0005\u0005\u0000\u0000\u0ab9\u0abb\u0005"+
		"\u001f\u0000\u0000\u0aba\u0abc\u0003\u0250\u0128\u0000\u0abb\u0aba\u0001"+
		"\u0000\u0000\u0000\u0abb\u0abc\u0001\u0000\u0000\u0000\u0abc\u0abe\u0001"+
		"\u0000\u0000\u0000\u0abd\u0ab9\u0001\u0000\u0000\u0000\u0abd\u0abe\u0001"+
		"\u0000\u0000\u0000\u0abe\u0abf\u0001\u0000\u0000\u0000\u0abf\u0ac1\u0005"+
		"\u00b5\u0000\u0000\u0ac0\u0ac2\u0007\u0017\u0000\u0000\u0ac1\u0ac0\u0001"+
		"\u0000\u0000\u0000\u0ac1\u0ac2\u0001\u0000\u0000\u0000\u0ac2\u0ac4\u0001"+
		"\u0000\u0000\u0000\u0ac3\u0ac5\u0003\u028a\u0145\u0000\u0ac4\u0ac3\u0001"+
		"\u0000\u0000\u0000\u0ac4\u0ac5\u0001\u0000\u0000\u0000\u0ac5\u0ac7\u0001"+
		"\u0000\u0000\u0000\u0ac6\u0ac8\u0003\u0250\u0128\u0000\u0ac7\u0ac6\u0001"+
		"\u0000\u0000\u0000\u0ac7\u0ac8\u0001\u0000\u0000\u0000\u0ac8\u0aca\u0001"+
		"\u0000\u0000\u0000\u0ac9\u0acb\u0003R)\u0000\u0aca\u0ac9\u0001\u0000\u0000"+
		"\u0000\u0aca\u0acb\u0001\u0000\u0000\u0000\u0acb\u0acc\u0001\u0000\u0000"+
		"\u0000\u0acc\u0ad0\u0003\u0276\u013b\u0000\u0acd\u0acf\u0003T*\u0000\u0ace"+
		"\u0acd\u0001\u0000\u0000\u0000\u0acf\u0ad2\u0001\u0000\u0000\u0000\u0ad0"+
		"\u0ace\u0001\u0000\u0000\u0000\u0ad0\u0ad1\u0001\u0000\u0000\u0000\u0ad1"+
		"\u0ba7\u0001\u0000\u0000\u0000\u0ad2\u0ad0\u0001\u0000\u0000\u0000\u0ad3"+
		"\u0ad4\u0005\u0005\u0000\u0000\u0ad4\u0ad6\u0007\u0019\u0000\u0000\u0ad5"+
		"\u0ad7\u0007\u0017\u0000\u0000\u0ad6\u0ad5\u0001\u0000\u0000\u0000\u0ad6"+
		"\u0ad7\u0001\u0000\u0000\u0000\u0ad7\u0ad9\u0001\u0000\u0000\u0000\u0ad8"+
		"\u0ada\u0003\u0250\u0128\u0000\u0ad9\u0ad8\u0001\u0000\u0000\u0000\u0ad9"+
		"\u0ada\u0001\u0000\u0000\u0000\u0ada\u0adb\u0001\u0000\u0000\u0000\u0adb"+
		"\u0adf\u0003\u0276\u013b\u0000\u0adc\u0ade\u0003T*\u0000\u0add\u0adc\u0001"+
		"\u0000\u0000\u0000\u0ade\u0ae1\u0001\u0000\u0000\u0000\u0adf\u0add\u0001"+
		"\u0000\u0000\u0000\u0adf\u0ae0\u0001\u0000\u0000\u0000\u0ae0\u0ba7\u0001"+
		"\u0000\u0000\u0000\u0ae1\u0adf\u0001\u0000\u0000\u0000\u0ae2\u0ae7\u0005"+
		"\u0005\u0000\u0000\u0ae3\u0ae5\u0005\u001f\u0000\u0000\u0ae4\u0ae6\u0003"+
		"\u0250\u0128\u0000\u0ae5\u0ae4\u0001\u0000\u0000\u0000\u0ae5\u0ae6\u0001"+
		"\u0000\u0000\u0000\u0ae6\u0ae8\u0001\u0000\u0000\u0000\u0ae7\u0ae3\u0001"+
		"\u0000\u0000\u0000\u0ae7\u0ae8\u0001\u0000\u0000\u0000\u0ae8\u0ae9\u0001"+
		"\u0000\u0000\u0000\u0ae9\u0aea\u0005C\u0000\u0000\u0aea\u0aec\u0005[\u0000"+
		"\u0000\u0aeb\u0aed\u0003\u028a\u0145\u0000\u0aec\u0aeb\u0001\u0000\u0000"+
		"\u0000\u0aec\u0aed\u0001\u0000\u0000\u0000\u0aed\u0aef\u0001\u0000\u0000"+
		"\u0000\u0aee\u0af0\u0003\u0250\u0128\u0000\u0aef\u0aee\u0001\u0000\u0000"+
		"\u0000\u0aef\u0af0\u0001\u0000\u0000\u0000\u0af0\u0af1\u0001\u0000\u0000"+
		"\u0000\u0af1\u0af2\u0003\u0276\u013b\u0000\u0af2\u0af3\u0003h4\u0000\u0af3"+
		"\u0ba7\u0001\u0000\u0000\u0000\u0af4\u0af9\u0005\u0005\u0000\u0000\u0af5"+
		"\u0af7\u0005\u001f\u0000\u0000\u0af6\u0af8\u0003\u0250\u0128\u0000\u0af7"+
		"\u0af6\u0001\u0000\u0000\u0000\u0af7\u0af8\u0001\u0000\u0000\u0000\u0af8"+
		"\u0afa\u0001\u0000\u0000\u0000\u0af9\u0af5\u0001\u0000\u0000\u0000\u0af9"+
		"\u0afa\u0001\u0000\u0000\u0000\u0afa\u0afb\u0001\u0000\u0000\u0000\u0afb"+
		"\u0afc\u0005\u001b\u0000\u0000\u0afc\u0afd\u0005\u0482\u0000\u0000\u0afd"+
		"\u0afe\u0003\u02ba\u015d\u0000\u0afe\u0aff\u0005\u0483\u0000\u0000\u0aff"+
		"\u0ba7\u0001\u0000\u0000\u0000\u0b00\u0b02\u0005\u0150\u0000\u0000\u0b01"+
		"\u0b03\u0005\u0479\u0000\u0000\u0b02\u0b01\u0001\u0000\u0000\u0000\u0b02"+
		"\u0b03\u0001\u0000\u0000\u0000\u0b03\u0b04\u0001\u0000\u0000\u0000\u0b04"+
		"\u0ba7\u0007\u0003\u0000\u0000\u0b05\u0b07\u0005\u0007\u0000\u0000\u0b06"+
		"\u0b08\u0005\u001d\u0000\u0000\u0b07\u0b06\u0001\u0000\u0000\u0000\u0b07"+
		"\u0b08\u0001\u0000\u0000\u0000\u0b08\u0b09\u0001\u0000\u0000\u0000\u0b09"+
		"\u0b0f\u0003\u0250\u0128\u0000\u0b0a\u0b0b\u0005\u009a\u0000\u0000\u0b0b"+
		"\u0b0c\u0005+\u0000\u0000\u0b0c\u0b10\u0003\u0282\u0141\u0000\u0b0d\u0b0e"+
		"\u00054\u0000\u0000\u0b0e\u0b10\u0005+\u0000\u0000\u0b0f\u0b0a\u0001\u0000"+
		"\u0000\u0000\u0b0f\u0b0d\u0001\u0000\u0000\u0000\u0b10\u0ba7\u0001\u0000"+
		"\u0000\u0000\u0b11\u0b13\u0005\u0019\u0000\u0000\u0b12\u0b14\u0005\u001d"+
		"\u0000\u0000\u0b13\u0b12\u0001\u0000\u0000\u0000\u0b13\u0b14\u0001\u0000"+
		"\u0000\u0000\u0b14\u0b16\u0001\u0000\u0000\u0000\u0b15\u0b17\u0003\u0288"+
		"\u0144\u0000\u0b16\u0b15\u0001\u0000\u0000\u0000\u0b16\u0b17\u0001\u0000"+
		"\u0000\u0000\u0b17\u0b18\u0001\u0000\u0000\u0000\u0b18\u0b19\u0003\u0250"+
		"\u0128\u0000\u0b19\u0b1a\u0003\u0250\u0128\u0000\u0b1a\u0b1e\u0003b1\u0000"+
		"\u0b1b\u0b1f\u0005\u01ae\u0000\u0000\u0b1c\u0b1d\u0005\u014e\u0000\u0000"+
		"\u0b1d\u0b1f\u0003\u0250\u0128\u0000\u0b1e\u0b1b\u0001\u0000\u0000\u0000"+
		"\u0b1e\u0b1c\u0001\u0000\u0000\u0000\u0b1e\u0b1f\u0001\u0000\u0000\u0000"+
		"\u0b1f\u0ba7\u0001\u0000\u0000\u0000\u0b20\u0b21\u0005\u008c\u0000\u0000"+
		"\u0b21\u0b22\u0005\u001d\u0000\u0000\u0b22\u0b23\u0003\u0250\u0128\u0000"+
		"\u0b23\u0b24\u0005\u00af\u0000\u0000\u0b24\u0b25\u0003\u0250\u0128\u0000"+
		"\u0b25\u0ba7\u0001\u0000\u0000\u0000\u0b26\u0b28\u0005g\u0000\u0000\u0b27"+
		"\u0b29\u0005\u0479\u0000\u0000\u0b28\u0b27\u0001\u0000\u0000\u0000\u0b28"+
		"\u0b29\u0001\u0000\u0000\u0000\u0b29\u0b2a\u0001\u0000\u0000\u0000\u0b2a"+
		"\u0ba7\u0007\u0004\u0000\u0000\u0b2b\u0b2d\u0005\u0201\u0000\u0000\u0b2c"+
		"\u0b2e\u0005\u001d\u0000\u0000\u0b2d\u0b2c\u0001\u0000\u0000\u0000\u0b2d"+
		"\u0b2e\u0001\u0000\u0000\u0000\u0b2e\u0b30\u0001\u0000\u0000\u0000\u0b2f"+
		"\u0b31\u0003\u0288\u0144\u0000\u0b30\u0b2f\u0001\u0000\u0000\u0000\u0b30"+
		"\u0b31\u0001\u0000\u0000\u0000\u0b31\u0b32\u0001\u0000\u0000\u0000\u0b32"+
		"\u0b33\u0003\u0250\u0128\u0000\u0b33\u0b37\u0003b1\u0000\u0b34\u0b38\u0005"+
		"\u01ae\u0000\u0000\u0b35\u0b36\u0005\u014e\u0000\u0000\u0b36\u0b38\u0003"+
		"\u0250\u0128\u0000\u0b37\u0b34\u0001\u0000\u0000\u0000\u0b37\u0b35\u0001"+
		"\u0000\u0000\u0000\u0b37\u0b38\u0001\u0000\u0000\u0000\u0b38\u0ba7\u0001"+
		"\u0000\u0000\u0000\u0b39\u0b3b\u00054\u0000\u0000\u0b3a\u0b3c\u0005\u001d"+
		"\u0000\u0000\u0b3b\u0b3a\u0001\u0000\u0000\u0000\u0b3b\u0b3c\u0001\u0000"+
		"\u0000\u0000\u0b3c\u0b3e\u0001\u0000\u0000\u0000\u0b3d\u0b3f\u0003\u0288"+
		"\u0144\u0000\u0b3e\u0b3d\u0001\u0000\u0000\u0000\u0b3e\u0b3f\u0001\u0000"+
		"\u0000\u0000\u0b3f\u0b40\u0001\u0000\u0000\u0000\u0b40\u0b42\u0003\u0250"+
		"\u0128\u0000\u0b41\u0b43\u0005\u0091\u0000\u0000\u0b42\u0b41\u0001\u0000"+
		"\u0000\u0000\u0b42\u0b43\u0001\u0000\u0000\u0000\u0b43\u0ba7\u0001\u0000"+
		"\u0000\u0000\u0b44\u0b45\u00054\u0000\u0000\u0b45\u0b47\u0007%\u0000\u0000"+
		"\u0b46\u0b48\u0003\u0288\u0144\u0000\u0b47\u0b46\u0001\u0000\u0000\u0000"+
		"\u0b47\u0b48\u0001\u0000\u0000\u0000\u0b48\u0b49\u0001\u0000\u0000\u0000"+
		"\u0b49\u0ba7\u0003\u0250\u0128\u0000\u0b4a\u0b4b\u00054\u0000\u0000\u0b4b"+
		"\u0b4c\u0005\u0082\u0000\u0000\u0b4c\u0ba7\u0005[\u0000\u0000\u0b4d\u0b4e"+
		"\u00054\u0000\u0000\u0b4e\u0b50\u0007\u0017\u0000\u0000\u0b4f\u0b51\u0003"+
		"\u0288\u0144\u0000\u0b50\u0b4f\u0001\u0000\u0000\u0000\u0b50\u0b51\u0001"+
		"\u0000\u0000\u0000\u0b51\u0b52\u0001\u0000\u0000\u0000\u0b52\u0ba7\u0003"+
		"\u0250\u0128\u0000\u0b53\u0b54\u0005\u008c\u0000\u0000\u0b54\u0b55\u0007"+
		"\u0017\u0000\u0000\u0b55\u0b56\u0003\u0250\u0128\u0000\u0b56\u0b57\u0005"+
		"\u00af\u0000\u0000\u0b57\u0b58\u0003\u0250\u0128\u0000\u0b58\u0ba7\u0001"+
		"\u0000\u0000\u0000\u0b59\u0b5a\u0005\u0007\u0000\u0000\u0b5a\u0b5b\u0005"+
		"Q\u0000\u0000\u0b5b\u0b5c\u0003\u0250\u0128\u0000\u0b5c\u0b5d\u0007\u0011"+
		"\u0000\u0000\u0b5d\u0ba7\u0001\u0000\u0000\u0000\u0b5e\u0b5f\u00054\u0000"+
		"\u0000\u0b5f\u0b60\u0005C\u0000\u0000\u0b60\u0b62\u0005[\u0000\u0000\u0b61"+
		"\u0b63\u0003\u0288\u0144\u0000\u0b62\u0b61\u0001\u0000\u0000\u0000\u0b62"+
		"\u0b63\u0001\u0000\u0000\u0000\u0b63\u0b64\u0001\u0000\u0000\u0000\u0b64"+
		"\u0b66\u0003\u0250\u0128\u0000\u0b65\u0b67\u0003\u0254\u012a\u0000\u0b66"+
		"\u0b65\u0001\u0000\u0000\u0000\u0b66\u0b67\u0001\u0000\u0000\u0000\u0b67"+
		"\u0ba7\u0001\u0000\u0000\u0000\u0b68\u0b69\u0005\u018c\u0000\u0000\u0b69"+
		"\u0ba7\u0005\\\u0000\u0000\u0b6a\u0b6b\u0005\u0193\u0000\u0000\u0b6b\u0ba7"+
		"\u0005\\\u0000\u0000\u0b6c\u0b6e\u0005\u008c\u0000\u0000\u0b6d\u0b6f\u0007"+
		"&\u0000\u0000\u0b6e\u0b6d\u0001\u0000\u0000\u0000\u0b6e\u0b6f\u0001\u0000"+
		"\u0000\u0000\u0b6f\u0b72\u0001\u0000\u0000\u0000\u0b70\u0b73\u0003\u0250"+
		"\u0128\u0000\u0b71\u0b73\u0003\u022c\u0116\u0000\u0b72\u0b70\u0001\u0000"+
		"\u0000\u0000\u0b72\u0b71\u0001\u0000\u0000\u0000\u0b73\u0ba7\u0001\u0000"+
		"\u0000\u0000\u0b74\u0b75\u0005|\u0000\u0000\u0b75\u0b76\u0005\u0014\u0000"+
		"\u0000\u0b76\u0ba7\u0003\u0272\u0139\u0000\u0b77\u0b78\u0005!\u0000\u0000"+
		"\u0b78\u0b79\u0005\u00af\u0000\u0000\u0b79\u0b7a\u0005\u001a\u0000\u0000"+
		"\u0b7a\u0b7b\u0005\u009a\u0000\u0000\u0b7b\u0b7e\u0003\u023e\u011f\u0000"+
		"\u0b7c\u0b7d\u0005\u001c\u0000\u0000\u0b7d\u0b7f\u0003\u0240\u0120\u0000"+
		"\u0b7e\u0b7c\u0001\u0000\u0000\u0000\u0b7e\u0b7f\u0001\u0000\u0000\u0000"+
		"\u0b7f\u0ba7\u0001\u0000\u0000\u0000\u0b80\u0b82\u0005+\u0000\u0000\u0b81"+
		"\u0b80\u0001\u0000\u0000\u0000\u0b81\u0b82\u0001\u0000\u0000\u0000\u0b82"+
		"\u0b83\u0001\u0000\u0000\u0000\u0b83\u0b84\u0005\u001a\u0000\u0000\u0b84"+
		"\u0b85\u0005\u009a\u0000\u0000\u0b85\u0b86\u0005\u0479\u0000\u0000\u0b86"+
		"\u0b8a\u0003\u023e\u011f\u0000\u0b87\u0b88\u0005\u001c\u0000\u0000\u0b88"+
		"\u0b89\u0005\u0479\u0000\u0000\u0b89\u0b8b\u0003\u0240\u0120\u0000\u0b8a"+
		"\u0b87\u0001\u0000\u0000\u0000\u0b8a\u0b8b\u0001\u0000\u0000\u0000\u0b8b"+
		"\u0ba7\u0001\u0000\u0000\u0000\u0b8c\u0b8d\u0005\u018d\u0000\u0000\u0b8d"+
		"\u0ba7\u0005\u028a\u0000\u0000\u0b8e\u0b8f\u0005\u01c2\u0000\u0000\u0b8f"+
		"\u0ba7\u0005\u028a\u0000\u0000\u0b90\u0ba7\u0005B\u0000\u0000\u0b91\u0b92"+
		"\u0007\'\u0000\u0000\u0b92\u0ba7\u0005\u02a0\u0000\u0000\u0b93\u0b95\u0005"+
		"\u0005\u0000\u0000\u0b94\u0b96\u0005\u001d\u0000\u0000\u0b95\u0b94\u0001"+
		"\u0000\u0000\u0000\u0b95\u0b96\u0001\u0000\u0000\u0000\u0b96\u0b98\u0001"+
		"\u0000\u0000\u0000\u0b97\u0b99\u0003\u028a\u0145\u0000\u0b98\u0b97\u0001"+
		"\u0000\u0000\u0000\u0b98\u0b99\u0001\u0000\u0000\u0000\u0b99\u0b9a\u0001"+
		"\u0000\u0000\u0000\u0b9a\u0b9b\u0005\u0482\u0000\u0000\u0b9b\u0ba0\u0003"+
		"`0\u0000\u0b9c\u0b9d\u0005\u0484\u0000\u0000\u0b9d\u0b9f\u0003`0\u0000"+
		"\u0b9e\u0b9c\u0001\u0000\u0000\u0000\u0b9f\u0ba2\u0001\u0000\u0000\u0000"+
		"\u0ba0\u0b9e\u0001\u0000\u0000\u0000\u0ba0\u0ba1\u0001\u0000\u0000\u0000"+
		"\u0ba1\u0ba3\u0001\u0000\u0000\u0000\u0ba2\u0ba0\u0001\u0000\u0000\u0000"+
		"\u0ba3\u0ba4\u0005\u0483\u0000\u0000\u0ba4\u0ba7\u0001\u0000\u0000\u0000"+
		"\u0ba5\u0ba7\u0003\u009eO\u0000\u0ba6\u0a63\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0a6d\u0001\u0000\u0000\u0000\u0ba6\u0a7b\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0a90\u0001\u0000\u0000\u0000\u0ba6\u0aa2\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0ab8\u0001\u0000\u0000\u0000\u0ba6\u0ad3\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0ae2\u0001\u0000\u0000\u0000\u0ba6\u0af4\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b00\u0001\u0000\u0000\u0000\u0ba6\u0b05\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b11\u0001\u0000\u0000\u0000\u0ba6\u0b20\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b26\u0001\u0000\u0000\u0000\u0ba6\u0b2b\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b39\u0001\u0000\u0000\u0000\u0ba6\u0b44\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b4a\u0001\u0000\u0000\u0000\u0ba6\u0b4d\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b53\u0001\u0000\u0000\u0000\u0ba6\u0b59\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b5e\u0001\u0000\u0000\u0000\u0ba6\u0b68\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b6a\u0001\u0000\u0000\u0000\u0ba6\u0b6c\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b74\u0001\u0000\u0000\u0000\u0ba6\u0b77\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b81\u0001\u0000\u0000\u0000\u0ba6\u0b8c\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b8e\u0001\u0000\u0000\u0000\u0ba6\u0b90\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0b91\u0001\u0000\u0000\u0000\u0ba6\u0b93\u0001\u0000\u0000\u0000\u0ba6"+
		"\u0ba5\u0001\u0000\u0000\u0000\u0ba7\u009d\u0001\u0000\u0000\u0000\u0ba8"+
		"\u0ba9\u0005\u0005\u0000\u0000\u0ba9\u0bab\u0005\u0081\u0000\u0000\u0baa"+
		"\u0bac\u0003\u028a\u0145\u0000\u0bab\u0baa\u0001\u0000\u0000\u0000\u0bab"+
		"\u0bac\u0001\u0000\u0000\u0000\u0bac\u0bad\u0001\u0000\u0000\u0000\u0bad"+
		"\u0bae\u0005\u0482\u0000\u0000\u0bae\u0bb3\u0003|>\u0000\u0baf\u0bb0\u0005"+
		"\u0484\u0000\u0000\u0bb0\u0bb2\u0003|>\u0000\u0bb1\u0baf\u0001\u0000\u0000"+
		"\u0000\u0bb2\u0bb5\u0001\u0000\u0000\u0000\u0bb3\u0bb1\u0001\u0000\u0000"+
		"\u0000\u0bb3\u0bb4\u0001\u0000\u0000\u0000\u0bb4\u0bb6\u0001\u0000\u0000"+
		"\u0000\u0bb5\u0bb3\u0001\u0000\u0000\u0000\u0bb6\u0bb7\u0005\u0483\u0000"+
		"\u0000\u0bb7\u0c11\u0001\u0000\u0000\u0000\u0bb8\u0bb9\u00054\u0000\u0000"+
		"\u0bb9\u0bbb\u0005\u0081\u0000\u0000\u0bba\u0bbc\u0003\u0288\u0144\u0000"+
		"\u0bbb\u0bba\u0001\u0000\u0000\u0000\u0bbb\u0bbc\u0001\u0000\u0000\u0000"+
		"\u0bbc\u0bbd\u0001\u0000\u0000\u0000\u0bbd\u0c11\u0003\u0272\u0139\u0000"+
		"\u0bbe\u0bbf\u0005\u018d\u0000\u0000\u0bbf\u0bc2\u0005\u0081\u0000\u0000"+
		"\u0bc0\u0bc3\u0003\u0272\u0139\u0000\u0bc1\u0bc3\u0005\u0006\u0000\u0000"+
		"\u0bc2\u0bc0\u0001\u0000\u0000\u0000\u0bc2\u0bc1\u0001\u0000\u0000\u0000"+
		"\u0bc3\u0bc4\u0001\u0000\u0000\u0000\u0bc4\u0c11\u0005\u028a\u0000\u0000"+
		"\u0bc5\u0bc6\u0005\u01c2\u0000\u0000\u0bc6\u0bc9\u0005\u0081\u0000\u0000"+
		"\u0bc7\u0bca\u0003\u0272\u0139\u0000\u0bc8\u0bca\u0005\u0006\u0000\u0000"+
		"\u0bc9\u0bc7\u0001\u0000\u0000\u0000\u0bc9\u0bc8\u0001\u0000\u0000\u0000"+
		"\u0bca\u0bcb\u0001\u0000\u0000\u0000\u0bcb\u0c11\u0005\u028a\u0000\u0000"+
		"\u0bcc\u0bcd\u0005\u0293\u0000\u0000\u0bcd\u0bd0\u0005\u0081\u0000\u0000"+
		"\u0bce\u0bd1\u0003\u0272\u0139\u0000\u0bcf\u0bd1\u0005\u0006\u0000\u0000"+
		"\u0bd0\u0bce\u0001\u0000\u0000\u0000\u0bd0\u0bcf\u0001\u0000\u0000\u0000"+
		"\u0bd1\u0c11\u0001\u0000\u0000\u0000\u0bd2\u0bd3\u0005\u016b\u0000\u0000"+
		"\u0bd3\u0bd4\u0005\u0081\u0000\u0000\u0bd4\u0c11\u0003\u0256\u012b\u0000"+
		"\u0bd5\u0bd6\u0005\u0245\u0000\u0000\u0bd6\u0bd7\u0005\u0081\u0000\u0000"+
		"\u0bd7\u0bd8\u0003\u0272\u0139\u0000\u0bd8\u0bd9\u0005W\u0000\u0000\u0bd9"+
		"\u0bda\u0005\u0482\u0000\u0000\u0bda\u0bdf\u0003|>\u0000\u0bdb\u0bdc\u0005"+
		"\u0484\u0000\u0000\u0bdc\u0bde\u0003|>\u0000\u0bdd\u0bdb\u0001\u0000\u0000"+
		"\u0000\u0bde\u0be1\u0001\u0000\u0000\u0000\u0bdf\u0bdd\u0001\u0000\u0000"+
		"\u0000\u0bdf\u0be0\u0001\u0000\u0000\u0000\u0be0\u0be2\u0001\u0000\u0000"+
		"\u0000\u0be1\u0bdf\u0001\u0000\u0000\u0000\u0be2\u0be3\u0005\u0483\u0000"+
		"\u0000\u0be3\u0c11\u0001\u0000\u0000\u0000\u0be4\u0be5\u0005\u01a2\u0000"+
		"\u0000\u0be5\u0be6\u0005\u0081\u0000\u0000\u0be6\u0be7\u0003\u0250\u0128"+
		"\u0000\u0be7\u0be8\u0005\u00c0\u0000\u0000\u0be8\u0be9\u0005\u00ac\u0000"+
		"\u0000\u0be9\u0bec\u0003\u022e\u0117\u0000\u0bea\u0beb\u0007\'\u0000\u0000"+
		"\u0beb\u0bed\u0005\u02a0\u0000\u0000\u0bec\u0bea\u0001\u0000\u0000\u0000"+
		"\u0bec\u0bed\u0001\u0000\u0000\u0000\u0bed\u0c11\u0001\u0000\u0000\u0000"+
		"\u0bee\u0bef\u0005\t\u0000\u0000\u0bef\u0bf2\u0005\u0081\u0000\u0000\u0bf0"+
		"\u0bf3\u0003\u0272\u0139\u0000\u0bf1\u0bf3\u0005\u0006\u0000\u0000\u0bf2"+
		"\u0bf0\u0001\u0000\u0000\u0000\u0bf2\u0bf1\u0001\u0000\u0000\u0000\u0bf3"+
		"\u0c11\u0001\u0000\u0000\u0000\u0bf4\u0bf5\u0005\u001b\u0000\u0000\u0bf5"+
		"\u0bf8\u0005\u0081\u0000\u0000\u0bf6\u0bf9\u0003\u0272\u0139\u0000\u0bf7"+
		"\u0bf9\u0005\u0006\u0000\u0000\u0bf8\u0bf6\u0001\u0000\u0000\u0000\u0bf8"+
		"\u0bf7\u0001\u0000\u0000\u0000\u0bf9\u0c11\u0001\u0000\u0000\u0000\u0bfa"+
		"\u0bfb\u0005w\u0000\u0000\u0bfb\u0bfe\u0005\u0081\u0000\u0000\u0bfc\u0bff"+
		"\u0003\u0272\u0139\u0000\u0bfd\u0bff\u0005\u0006\u0000\u0000\u0bfe\u0bfc"+
		"\u0001\u0000\u0000\u0000\u0bfe\u0bfd\u0001\u0000\u0000\u0000\u0bff\u0c11"+
		"\u0001\u0000\u0000\u0000\u0c00\u0c01\u0005\u023b\u0000\u0000\u0c01\u0c04"+
		"\u0005\u0081\u0000\u0000\u0c02\u0c05\u0003\u0272\u0139\u0000\u0c03\u0c05"+
		"\u0005\u0006\u0000\u0000\u0c04\u0c02\u0001\u0000\u0000\u0000\u0c04\u0c03"+
		"\u0001\u0000\u0000\u0000\u0c05\u0c11\u0001\u0000\u0000\u0000\u0c06\u0c07"+
		"\u0005\u0246\u0000\u0000\u0c07\u0c0a\u0005\u0081\u0000\u0000\u0c08\u0c0b"+
		"\u0003\u0272\u0139\u0000\u0c09\u0c0b\u0005\u0006\u0000\u0000\u0c0a\u0c08"+
		"\u0001\u0000\u0000\u0000\u0c0a\u0c09\u0001\u0000\u0000\u0000\u0c0b\u0c11"+
		"\u0001\u0000\u0000\u0000\u0c0c\u0c0d\u0005\u0244\u0000\u0000\u0c0d\u0c11"+
		"\u0005\u0226\u0000\u0000\u0c0e\u0c0f\u0005\u029c\u0000\u0000\u0c0f\u0c11"+
		"\u0005\u0226\u0000\u0000\u0c10\u0ba8\u0001\u0000\u0000\u0000\u0c10\u0bb8"+
		"\u0001\u0000\u0000\u0000\u0c10\u0bbe\u0001\u0000\u0000\u0000\u0c10\u0bc5"+
		"\u0001\u0000\u0000\u0000\u0c10\u0bcc\u0001\u0000\u0000\u0000\u0c10\u0bd2"+
		"\u0001\u0000\u0000\u0000\u0c10\u0bd5\u0001\u0000\u0000\u0000\u0c10\u0be4"+
		"\u0001\u0000\u0000\u0000\u0c10\u0bee\u0001\u0000\u0000\u0000\u0c10\u0bf4"+
		"\u0001\u0000\u0000\u0000\u0c10\u0bfa\u0001\u0000\u0000\u0000\u0c10\u0c00"+
		"\u0001\u0000\u0000\u0000\u0c10\u0c06\u0001\u0000\u0000\u0000\u0c10\u0c0c"+
		"\u0001\u0000\u0000\u0000\u0c10\u0c0e\u0001\u0000\u0000\u0000\u0c11\u009f"+
		"\u0001\u0000\u0000\u0000\u0c12\u0c13\u00054\u0000\u0000\u0c13\u0c15\u0007"+
		"\u0000\u0000\u0000\u0c14\u0c16\u0003\u0288\u0144\u0000\u0c15\u0c14\u0001"+
		"\u0000\u0000\u0000\u0c15\u0c16\u0001\u0000\u0000\u0000\u0c16\u0c17\u0001"+
		"\u0000\u0000\u0000\u0c17\u0c18\u0003\u0250\u0128\u0000\u0c18\u00a1\u0001"+
		"\u0000\u0000\u0000\u0c19\u0c1a\u00054\u0000\u0000\u0c1a\u0c1c\u0005\u019f"+
		"\u0000\u0000\u0c1b\u0c1d\u0003\u0288\u0144\u0000\u0c1c\u0c1b\u0001\u0000"+
		"\u0000\u0000\u0c1c\u0c1d\u0001\u0000\u0000\u0000\u0c1d\u0c1e\u0001\u0000"+
		"\u0000\u0000\u0c1e\u0c1f\u0003\u022c\u0116\u0000\u0c1f\u00a3\u0001\u0000"+
		"\u0000\u0000\u0c20\u0c21\u00054\u0000\u0000\u0c21\u0c23\u0005Q\u0000\u0000"+
		"\u0c22\u0c24\u0003\u0288\u0144\u0000\u0c23\u0c22\u0001\u0000\u0000\u0000"+
		"\u0c23\u0c24\u0001\u0000\u0000\u0000\u0c24\u0c26\u0001\u0000\u0000\u0000"+
		"\u0c25\u0c27\u0007\u0001\u0000\u0000\u0c26\u0c25\u0001\u0000\u0000\u0000"+
		"\u0c26\u0c27\u0001\u0000\u0000\u0000\u0c27\u0c28\u0001\u0000\u0000\u0000"+
		"\u0c28\u0c29\u0003\u0250\u0128\u0000\u0c29\u0c2a\u0005v\u0000\u0000\u0c2a"+
		"\u0c37\u0003\u022e\u0117\u0000\u0c2b\u0c2d\u0005\u0150\u0000\u0000\u0c2c"+
		"\u0c2e\u0005\u0479\u0000\u0000\u0c2d\u0c2c\u0001\u0000\u0000\u0000\u0c2d"+
		"\u0c2e\u0001\u0000\u0000\u0000\u0c2e\u0c2f\u0001\u0000\u0000\u0000\u0c2f"+
		"\u0c36\u0007(\u0000\u0000\u0c30\u0c32\u0005g\u0000\u0000\u0c31\u0c33\u0005"+
		"\u0479\u0000\u0000\u0c32\u0c31\u0001\u0000\u0000\u0000\u0c32\u0c33\u0001"+
		"\u0000\u0000\u0000\u0c33\u0c34\u0001\u0000\u0000\u0000\u0c34\u0c36\u0007"+
		"\u0004\u0000\u0000\u0c35\u0c2b\u0001\u0000\u0000\u0000\u0c35\u0c30\u0001"+
		"\u0000\u0000\u0000\u0c36\u0c39\u0001\u0000\u0000\u0000\u0c37\u0c35\u0001"+
		"\u0000\u0000\u0000\u0c37\u0c38\u0001\u0000\u0000\u0000\u0c38\u0c3b\u0001"+
		"\u0000\u0000\u0000\u0c39\u0c37\u0001\u0000\u0000\u0000\u0c3a\u0c3c\u0003"+
		"\u028e\u0147\u0000\u0c3b\u0c3a\u0001\u0000\u0000\u0000\u0c3b\u0c3c\u0001"+
		"\u0000\u0000\u0000\u0c3c\u00a5\u0001\u0000\u0000\u0000\u0c3d\u0c3e\u0005"+
		"4\u0000\u0000\u0c3e\u0c3f\u0005\u01dc\u0000\u0000\u0c3f\u0c40\u0005I\u0000"+
		"\u0000\u0c40\u0c41\u0003\u0250\u0128\u0000\u0c41\u0c42\u0005\u0199\u0000"+
		"\u0000\u0c42\u0c43\u0005\u0479\u0000\u0000\u0c43\u0c44\u0003\u0242\u0121"+
		"\u0000\u0c44\u00a7\u0001\u0000\u0000\u0000\u0c45\u0c46\u00054\u0000\u0000"+
		"\u0c46\u0c48\u0005\u0084\u0000\u0000\u0c47\u0c49\u0003\u0288\u0144\u0000"+
		"\u0c48\u0c47\u0001\u0000\u0000\u0000\u0c48\u0c49\u0001\u0000\u0000\u0000"+
		"\u0c49\u0c4a\u0001\u0000\u0000\u0000\u0c4a\u0c4b\u0003\u022c\u0116\u0000"+
		"\u0c4b\u00a9\u0001\u0000\u0000\u0000\u0c4c\u0c4d\u00054\u0000\u0000\u0c4d"+
		"\u0c4f\u0005\u01b5\u0000\u0000\u0c4e\u0c50\u0003\u0288\u0144\u0000\u0c4f"+
		"\u0c4e\u0001\u0000\u0000\u0000\u0c4f\u0c50\u0001\u0000\u0000\u0000\u0c50"+
		"\u0c51\u0001\u0000\u0000\u0000\u0c51\u0c52\u0003\u022c\u0116\u0000\u0c52"+
		"\u00ab\u0001\u0000\u0000\u0000\u0c53\u0c54\u00054\u0000\u0000\u0c54\u0c56"+
		"\u0005\u0262\u0000\u0000\u0c55\u0c57\u0003\u0288\u0144\u0000\u0c56\u0c55"+
		"\u0001\u0000\u0000\u0000\u0c56\u0c57\u0001\u0000\u0000\u0000\u0c57\u0c58"+
		"\u0001\u0000\u0000\u0000\u0c58\u0c59\u0003\u0250\u0128\u0000\u0c59\u00ad"+
		"\u0001\u0000\u0000\u0000\u0c5a\u0c5c\u00054\u0000\u0000\u0c5b\u0c5d\u0005"+
		"\u028c\u0000\u0000\u0c5c\u0c5b\u0001\u0000\u0000\u0000\u0c5c\u0c5d\u0001"+
		"\u0000\u0000\u0000\u0c5d\u0c5e\u0001\u0000\u0000\u0000\u0c5e\u0c60\u0005"+
		"\u00ac\u0000\u0000\u0c5f\u0c61\u0003\u0288\u0144\u0000\u0c60\u0c5f\u0001"+
		"\u0000\u0000\u0000\u0c60\u0c61\u0001\u0000\u0000\u0000\u0c61\u0c62\u0001"+
		"\u0000\u0000\u0000\u0c62\u0c64\u0003\u0274\u013a\u0000\u0c63\u0c65\u0003"+
		"\u028e\u0147\u0000\u0c64\u0c63\u0001\u0000\u0000\u0000\u0c64\u0c65\u0001"+
		"\u0000\u0000\u0000\u0c65\u0c67\u0001\u0000\u0000\u0000\u0c66\u0c68\u0007"+
		")\u0000\u0000\u0c67\u0c66\u0001\u0000\u0000\u0000\u0c67\u0c68\u0001\u0000"+
		"\u0000\u0000\u0c68\u00af\u0001\u0000\u0000\u0000\u0c69\u0c6a\u00054\u0000"+
		"\u0000\u0c6a\u0c6b\u0005\u028a\u0000\u0000\u0c6b\u0c71\u0003\u0250\u0128"+
		"\u0000\u0c6c\u0c6e\u0005\u0199\u0000\u0000\u0c6d\u0c6f\u0005\u0479\u0000"+
		"\u0000\u0c6e\u0c6d\u0001\u0000\u0000\u0000\u0c6e\u0c6f\u0001\u0000\u0000"+
		"\u0000\u0c6f\u0c70\u0001\u0000\u0000\u0000\u0c70\u0c72\u0003\u0242\u0121"+
		"\u0000\u0c71\u0c6c\u0001\u0000\u0000\u0000\u0c71\u0c72\u0001\u0000\u0000"+
		"\u0000\u0c72\u00b1\u0001\u0000\u0000\u0000\u0c73\u0c74\u00054\u0000\u0000"+
		"\u0c74\u0c76\u0005\u00b1\u0000\u0000\u0c75\u0c77\u0003\u0288\u0144\u0000"+
		"\u0c76\u0c75\u0001\u0000\u0000\u0000\u0c76\u0c77\u0001\u0000\u0000\u0000"+
		"\u0c77\u0c78\u0001\u0000\u0000\u0000\u0c78\u0c79\u0003\u022c\u0116\u0000"+
		"\u0c79\u00b3\u0001\u0000\u0000\u0000\u0c7a\u0c7b\u00054\u0000\u0000\u0c7b"+
		"\u0c7d\u0005\u02a3\u0000\u0000\u0c7c\u0c7e\u0003\u0288\u0144\u0000\u0c7d"+
		"\u0c7c\u0001\u0000\u0000\u0000\u0c7d\u0c7e\u0001\u0000\u0000\u0000\u0c7e"+
		"\u0c7f\u0001\u0000\u0000\u0000\u0c7f\u0c84\u0003\u022c\u0116\u0000\u0c80"+
		"\u0c81\u0005\u0484\u0000\u0000\u0c81\u0c83\u0003\u022c\u0116\u0000\u0c82"+
		"\u0c80\u0001\u0000\u0000\u0000\u0c83\u0c86\u0001\u0000\u0000\u0000\u0c84"+
		"\u0c82\u0001\u0000\u0000\u0000\u0c84\u0c85\u0001\u0000\u0000\u0000\u0c85"+
		"\u0c88\u0001\u0000\u0000\u0000\u0c86\u0c84\u0001\u0000\u0000\u0000\u0c87"+
		"\u0c89\u0007)\u0000\u0000\u0c88\u0c87\u0001\u0000\u0000\u0000\u0c88\u0c89"+
		"\u0001\u0000\u0000\u0000\u0c89\u00b5\u0001\u0000\u0000\u0000\u0c8a\u0c8b"+
		"\u00054\u0000\u0000\u0c8b\u0c8d\u0005\u0256\u0000\u0000\u0c8c\u0c8e\u0003"+
		"\u0288\u0144\u0000\u0c8d\u0c8c\u0001\u0000\u0000\u0000\u0c8d\u0c8e\u0001"+
		"\u0000\u0000\u0000\u0c8e\u0c8f\u0001\u0000\u0000\u0000\u0c8f\u0c94\u0003"+
		"\u0230\u0118\u0000\u0c90\u0c91\u0005\u0484\u0000\u0000\u0c91\u0c93\u0003"+
		"\u0230\u0118\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\u00b7\u0001\u0000\u0000\u0000\u0c96\u0c94\u0001"+
		"\u0000\u0000\u0000\u0c97\u0c98\u0005\u009a\u0000\u0000\u0c98\u0c99\u0005"+
		"+\u0000\u0000\u0c99\u0ca4\u0005\u0256\u0000\u0000\u0c9a\u0ca5\u0005\u0212"+
		"\u0000\u0000\u0c9b\u0ca5\u0005\u0006\u0000\u0000\u0c9c\u0ca1\u0003\u0230"+
		"\u0118\u0000\u0c9d\u0c9e\u0005\u0484\u0000\u0000\u0c9e\u0ca0\u0003\u0230"+
		"\u0118\u0000\u0c9f\u0c9d\u0001\u0000\u0000\u0000\u0ca0\u0ca3\u0001\u0000"+
		"\u0000\u0000\u0ca1\u0c9f\u0001\u0000\u0000\u0000\u0ca1\u0ca2\u0001\u0000"+
		"\u0000\u0000\u0ca2\u0ca5\u0001\u0000\u0000\u0000\u0ca3\u0ca1\u0001\u0000"+
		"\u0000\u0000\u0ca4\u0c9a\u0001\u0000\u0000\u0000\u0ca4\u0c9b\u0001\u0000"+
		"\u0000\u0000\u0ca4\u0c9c\u0001\u0000\u0000\u0000\u0ca5\u0ca6\u0001\u0000"+
		"\u0000\u0000\u0ca6\u0ca9\u0005\u00af\u0000\u0000\u0ca7\u0caa\u0003\u023a"+
		"\u011d\u0000\u0ca8\u0caa\u0003\u0250\u0128\u0000\u0ca9\u0ca7\u0001\u0000"+
		"\u0000\u0000\u0ca9\u0ca8\u0001\u0000\u0000\u0000\u0caa\u0cb2\u0001\u0000"+
		"\u0000\u0000\u0cab\u0cae\u0005\u0484\u0000\u0000\u0cac\u0caf\u0003\u023a"+
		"\u011d\u0000\u0cad\u0caf\u0003\u0250\u0128\u0000\u0cae\u0cac\u0001\u0000"+
		"\u0000\u0000\u0cae\u0cad\u0001\u0000\u0000\u0000\u0caf\u0cb1\u0001\u0000"+
		"\u0000\u0000\u0cb0\u0cab\u0001\u0000\u0000\u0000\u0cb1\u0cb4\u0001\u0000"+
		"\u0000\u0000\u0cb2\u0cb0\u0001\u0000\u0000\u0000\u0cb2\u0cb3\u0001\u0000"+
		"\u0000\u0000\u0cb3\u0cb9\u0001\u0000\u0000\u0000\u0cb4\u0cb2\u0001\u0000"+
		"\u0000\u0000\u0cb5\u0cb6\u0005\u009a\u0000\u0000\u0cb6\u0cb7\u0005\u0256"+
		"\u0000\u0000\u0cb7\u0cb9\u0003\u01ba\u00dd\u0000\u0cb8\u0c97\u0001\u0000"+
		"\u0000\u0000\u0cb8\u0cb5\u0001\u0000\u0000\u0000\u0cb9\u00b9\u0001\u0000"+
		"\u0000\u0000\u0cba\u0cbc\u00054\u0000\u0000\u0cbb\u0cbd\u0005\u028c\u0000"+
		"\u0000\u0cbc\u0cbb\u0001\u0000\u0000\u0000\u0cbc\u0cbd\u0001\u0000\u0000"+
		"\u0000\u0cbd\u0cbe\u0001\u0000\u0000\u0000\u0cbe\u0cc0\u0005\u0261\u0000"+
		"\u0000\u0cbf\u0cc1\u0003\u0288\u0144\u0000\u0cc0\u0cbf\u0001\u0000\u0000"+
		"\u0000\u0cc0\u0cc1\u0001\u0000\u0000\u0000\u0cc1\u0cc3\u0001\u0000\u0000"+
		"\u0000\u0cc2\u0cc4\u0005\u0003\u0000\u0000\u0cc3\u0cc2\u0001\u0000\u0000"+
		"\u0000\u0cc3\u0cc4\u0001\u0000\u0000\u0000\u0cc4\u0cc5\u0001\u0000\u0000"+
		"\u0000\u0cc5\u0cca\u0003\u022c\u0116\u0000\u0cc6\u0cc7\u0005\u0484\u0000"+
		"\u0000\u0cc7\u0cc9\u0003\u022c\u0116\u0000\u0cc8\u0cc6\u0001\u0000\u0000"+
		"\u0000\u0cc9\u0ccc\u0001\u0000\u0000\u0000\u0cca\u0cc8\u0001\u0000\u0000"+
		"\u0000\u0cca\u0ccb\u0001\u0000\u0000\u0000\u0ccb\u00bb\u0001\u0000\u0000"+
		"\u0000\u0ccc\u0cca\u0001\u0000\u0000\u0000\u0ccd\u0cce\u0005\u008c\u0000"+
		"\u0000\u0cce\u0cd0\u0005\u00ac\u0000\u0000\u0ccf\u0cd1\u0003\u0288\u0144"+
		"\u0000\u0cd0\u0ccf\u0001\u0000\u0000\u0000\u0cd0\u0cd1\u0001\u0000\u0000"+
		"\u0000\u0cd1\u0cd2\u0001\u0000\u0000\u0000\u0cd2\u0cd7\u0003\u00be_\u0000"+
		"\u0cd3\u0cd4\u0005\u0484\u0000\u0000\u0cd4\u0cd6\u0003\u00be_\u0000\u0cd5"+
		"\u0cd3\u0001\u0000\u0000\u0000\u0cd6\u0cd9\u0001\u0000\u0000\u0000\u0cd7"+
		"\u0cd5\u0001\u0000\u0000\u0000\u0cd7\u0cd8\u0001\u0000\u0000\u0000\u0cd8"+
		"\u00bd\u0001\u0000\u0000\u0000\u0cd9\u0cd7\u0001\u0000\u0000\u0000\u0cda"+
		"\u0cdc\u0003\u022e\u0117\u0000\u0cdb\u0cdd\u0003\u028e\u0147\u0000\u0cdc"+
		"\u0cdb\u0001\u0000\u0000\u0000\u0cdc\u0cdd\u0001\u0000\u0000\u0000\u0cdd"+
		"\u0cde\u0001\u0000\u0000\u0000\u0cde\u0cdf\u0005\u00af\u0000\u0000\u0cdf"+
		"\u0ce0\u0003\u022e\u0117\u0000\u0ce0\u00bf\u0001\u0000\u0000\u0000\u0ce1"+
		"\u0ce3\u0005\u0293\u0000\u0000\u0ce2\u0ce4\u0005\u00ac\u0000\u0000\u0ce3"+
		"\u0ce2\u0001\u0000\u0000\u0000\u0ce3\u0ce4\u0001\u0000\u0000\u0000\u0ce4"+
		"\u0ce5\u0001\u0000\u0000\u0000\u0ce5\u0ce7\u0003\u022e\u0117\u0000\u0ce6"+
		"\u0ce8\u0003\u028e\u0147\u0000\u0ce7\u0ce6\u0001\u0000\u0000\u0000\u0ce7"+
		"\u0ce8\u0001\u0000\u0000\u0000\u0ce8\u00c1\u0001\u0000\u0000\u0000\u0ce9"+
		"\u0cea\u0005\u0015\u0000\u0000\u0cea\u0cf1\u0003\u022c\u0116\u0000\u0ceb"+
		"\u0cee\u0005\u0482\u0000\u0000\u0cec\u0cef\u0003\u027c\u013e\u0000\u0ced"+
		"\u0cef\u0003\u0278\u013c\u0000\u0cee\u0cec\u0001\u0000\u0000\u0000\u0cee"+
		"\u0ced\u0001\u0000\u0000\u0000\u0cee\u0cef\u0001\u0000\u0000\u0000\u0cef"+
		"\u0cf0\u0001\u0000\u0000\u0000\u0cf0\u0cf2\u0005\u0483\u0000\u0000\u0cf1"+
		"\u0ceb\u0001\u0000\u0000\u0000\u0cf1\u0cf2\u0001\u0000\u0000\u0000\u0cf2"+
		"\u00c3\u0001\u0000\u0000\u0000\u0cf3\u0cf6\u0003\u00e0p\u0000\u0cf4\u0cf6"+
		"\u0003\u00e2q\u0000\u0cf5\u0cf3\u0001\u0000\u0000\u0000\u0cf5\u0cf4\u0001"+
		"\u0000\u0000\u0000\u0cf6\u00c5\u0001\u0000\u0000\u0000\u0cf7\u0cf8\u0005"+
		"\u018f\u0000\u0000\u0cf8\u0cf9\u0003\u0278\u013c\u0000\u0cf9\u00c7\u0001"+
		"\u0000\u0000\u0000\u0cfa\u0cff\u0003\u00e4r\u0000\u0cfb\u0cff\u0003\u00e6"+
		"s\u0000\u0cfc\u0cff\u0003\u00e8t\u0000\u0cfd\u0cff\u0003\u00eau\u0000"+
		"\u0cfe\u0cfa\u0001\u0000\u0000\u0000\u0cfe\u0cfb\u0001\u0000\u0000\u0000"+
		"\u0cfe\u0cfc\u0001\u0000\u0000\u0000\u0cfe\u0cfd\u0001\u0000\u0000\u0000"+
		"\u0cff\u00c9\u0001\u0000\u0000\u0000\u0d00\u0d02\u0005U\u0000\u0000\u0d01"+
		"\u0d03\u0007*\u0000\u0000\u0d02\u0d01\u0001\u0000\u0000\u0000\u0d02\u0d03"+
		"\u0001\u0000\u0000\u0000\u0d03\u0d05\u0001\u0000\u0000\u0000\u0d04\u0d06"+
		"\u0005N\u0000\u0000\u0d05\u0d04\u0001\u0000\u0000\u0000\u0d05\u0d06\u0001"+
		"\u0000\u0000\u0000\u0d06\u0d08\u0001\u0000\u0000\u0000\u0d07\u0d09\u0005"+
		"W\u0000\u0000\u0d08\u0d07\u0001\u0000\u0000\u0000\u0d08\u0d09\u0001\u0000"+
		"\u0000\u0000\u0d09\u0d0a\u0001\u0000\u0000\u0000\u0d0a\u0d11\u0003\u022e"+
		"\u0117\u0000\u0d0b\u0d0c\u0005\u0081\u0000\u0000\u0d0c\u0d0e\u0005\u0482"+
		"\u0000\u0000\u0d0d\u0d0f\u0003\u0272\u0139\u0000\u0d0e\u0d0d\u0001\u0000"+
		"\u0000\u0000\u0d0e\u0d0f\u0001\u0000\u0000\u0000\u0d0f\u0d10\u0001\u0000"+
		"\u0000\u0000\u0d10\u0d12\u0005\u0483\u0000\u0000\u0d11\u0d0b\u0001\u0000"+
		"\u0000\u0000\u0d11\u0d12\u0001\u0000\u0000\u0000\u0d12\u0d23\u0001\u0000"+
		"\u0000\u0000\u0d13\u0d14\u0005\u0482\u0000\u0000\u0d14\u0d15\u0003\u0272"+
		"\u0139\u0000\u0d15\u0d16\u0005\u0483\u0000\u0000\u0d16\u0d18\u0001\u0000"+
		"\u0000\u0000\u0d17\u0d13\u0001\u0000\u0000\u0000\u0d17\u0d18\u0001\u0000"+
		"\u0000\u0000\u0d18\u0d19\u0001\u0000\u0000\u0000\u0d19\u0d24\u0003\u00d8"+
		"l\u0000\u0d1a\u0d1b\u0005\u009a\u0000\u0000\u0d1b\u0d20\u0003\u00dam\u0000"+
		"\u0d1c\u0d1d\u0005\u0484\u0000\u0000\u0d1d\u0d1f\u0003\u00dam\u0000\u0d1e"+
		"\u0d1c\u0001\u0000\u0000\u0000\u0d1f\u0d22\u0001\u0000\u0000\u0000\u0d20"+
		"\u0d1e\u0001\u0000\u0000\u0000\u0d20\u0d21\u0001\u0000\u0000\u0000\u0d21"+
		"\u0d24\u0001\u0000\u0000\u0000\u0d22\u0d20\u0001\u0000\u0000\u0000\u0d23"+
		"\u0d17\u0001\u0000\u0000\u0000\u0d23\u0d1a\u0001\u0000\u0000\u0000\u0d24"+
		"\u0d31\u0001\u0000\u0000\u0000\u0d25\u0d26\u0005v\u0000\u0000\u0d26\u0d27"+
		"\u0005\u0191\u0000\u0000\u0d27\u0d28\u0005[\u0000\u0000\u0d28\u0d29\u0005"+
		"\u00b8\u0000\u0000\u0d29\u0d2e\u0003\u00dam\u0000\u0d2a\u0d2b\u0005\u0484"+
		"\u0000\u0000\u0d2b\u0d2d\u0003\u00dam\u0000\u0d2c\u0d2a\u0001\u0000\u0000"+
		"\u0000\u0d2d\u0d30\u0001\u0000\u0000\u0000\u0d2e\u0d2c\u0001\u0000\u0000"+
		"\u0000\u0d2e\u0d2f\u0001\u0000\u0000\u0000\u0d2f\u0d32\u0001\u0000\u0000"+
		"\u0000\u0d30\u0d2e\u0001\u0000\u0000\u0000\u0d31\u0d25\u0001\u0000\u0000"+
		"\u0000\u0d31\u0d32\u0001\u0000\u0000\u0000\u0d32\u00cb\u0001\u0000\u0000"+
		"\u0000\u0d33\u0d34\u0005f\u0000\u0000\u0d34\u0d36\u0005\u0184\u0000\u0000"+
		"\u0d35\u0d37\u0007+\u0000\u0000\u0d36\u0d35\u0001\u0000\u0000\u0000\u0d36"+
		"\u0d37\u0001\u0000\u0000\u0000\u0d37\u0d39\u0001\u0000\u0000\u0000\u0d38"+
		"\u0d3a\u0005\u01da\u0000\u0000\u0d39\u0d38\u0001\u0000\u0000\u0000\u0d39"+
		"\u0d3a\u0001\u0000\u0000\u0000\u0d3a\u0d3b\u0001\u0000\u0000\u0000\u0d3b"+
		"\u0d3c\u0005R\u0000\u0000\u0d3c\u0d3e\u0005\u0491\u0000\u0000\u0d3d\u0d3f"+
		"\u0007\u0006\u0000\u0000\u0d3e\u0d3d\u0001\u0000\u0000\u0000\u0d3e\u0d3f"+
		"\u0001\u0000\u0000\u0000\u0d3f\u0d40\u0001\u0000\u0000\u0000\u0d40\u0d41"+
		"\u0005W\u0000\u0000\u0d41\u0d42\u0005\u00ac\u0000\u0000\u0d42\u0d48\u0003"+
		"\u022e\u0117\u0000\u0d43\u0d44\u0005\u0081\u0000\u0000\u0d44\u0d45\u0005"+
		"\u0482\u0000\u0000\u0d45\u0d46\u0003\u0272\u0139\u0000\u0d46\u0d47\u0005"+
		"\u0483\u0000\u0000\u0d47\u0d49\u0001\u0000\u0000\u0000\u0d48\u0d43\u0001"+
		"\u0000\u0000\u0000\u0d48\u0d49\u0001\u0000\u0000\u0000\u0d49\u0d4d\u0001"+
		"\u0000\u0000\u0000\u0d4a\u0d4b\u0005\u001a\u0000\u0000\u0d4b\u0d4c\u0005"+
		"\u009a\u0000\u0000\u0d4c\u0d4e\u0003\u023e\u011f\u0000\u0d4d\u0d4a\u0001"+
		"\u0000\u0000\u0000\u0d4d\u0d4e\u0001\u0000\u0000\u0000\u0d4e\u0d55\u0001"+
		"\u0000\u0000\u0000\u0d4f\u0d51\u0007,\u0000\u0000\u0d50\u0d52\u0003\u0120"+
		"\u0090\u0000\u0d51\u0d50\u0001\u0000\u0000\u0000\u0d52\u0d53\u0001\u0000"+
		"\u0000\u0000\u0d53\u0d51\u0001\u0000\u0000\u0000\u0d53\u0d54\u0001\u0000"+
		"\u0000\u0000\u0d54\u0d56\u0001\u0000\u0000\u0000\u0d55\u0d4f\u0001\u0000"+
		"\u0000\u0000\u0d55\u0d56\u0001\u0000\u0000\u0000\u0d56\u0d5d\u0001\u0000"+
		"\u0000\u0000\u0d57\u0d59\u0005e\u0000\u0000\u0d58\u0d5a\u0003\u0122\u0091"+
		"\u0000\u0d59\u0d58\u0001\u0000\u0000\u0000\u0d5a\u0d5b\u0001\u0000\u0000"+
		"\u0000\u0d5b\u0d59\u0001\u0000\u0000\u0000\u0d5b\u0d5c\u0001\u0000\u0000"+
		"\u0000\u0d5c\u0d5e\u0001\u0000\u0000\u0000\u0d5d\u0d57\u0001\u0000\u0000"+
		"\u0000\u0d5d\u0d5e\u0001\u0000\u0000\u0000\u0d5e\u0d63\u0001\u0000\u0000"+
		"\u0000\u0d5f\u0d60\u0005N\u0000\u0000\u0d60\u0d61\u0003\u0256\u012b\u0000"+
		"\u0d61\u0d62\u0007-\u0000\u0000\u0d62\u0d64\u0001\u0000\u0000\u0000\u0d63"+
		"\u0d5f\u0001\u0000\u0000\u0000\u0d63\u0d64\u0001\u0000\u0000\u0000\u0d64"+
		"\u0d70\u0001\u0000\u0000\u0000\u0d65\u0d66\u0005\u0482\u0000\u0000\u0d66"+
		"\u0d6b\u0003\u00dcn\u0000\u0d67\u0d68\u0005\u0484\u0000\u0000\u0d68\u0d6a"+
		"\u0003\u00dcn\u0000\u0d69\u0d67\u0001\u0000\u0000\u0000\u0d6a\u0d6d\u0001"+
		"\u0000\u0000\u0000\u0d6b\u0d69\u0001\u0000\u0000\u0000\u0d6b\u0d6c\u0001"+
		"\u0000\u0000\u0000\u0d6c\u0d6e\u0001\u0000\u0000\u0000\u0d6d\u0d6b\u0001"+
		"\u0000\u0000\u0000\u0d6e\u0d6f\u0005\u0483\u0000\u0000\u0d6f\u0d71\u0001"+
		"\u0000\u0000\u0000\u0d70\u0d65\u0001\u0000\u0000\u0000\u0d70\u0d71\u0001"+
		"\u0000\u0000\u0000\u0d71\u0d7b\u0001\u0000\u0000\u0000\u0d72\u0d73\u0005"+
		"\u009a\u0000\u0000\u0d73\u0d78\u0003\u00dam\u0000\u0d74\u0d75\u0005\u0484"+
		"\u0000\u0000\u0d75\u0d77\u0003\u00dam\u0000\u0d76\u0d74\u0001\u0000\u0000"+
		"\u0000\u0d77\u0d7a\u0001\u0000\u0000\u0000\u0d78\u0d76\u0001\u0000\u0000"+
		"\u0000\u0d78\u0d79\u0001\u0000\u0000\u0000\u0d79\u0d7c\u0001\u0000\u0000"+
		"\u0000\u0d7a\u0d78\u0001\u0000\u0000\u0000\u0d7b\u0d72\u0001\u0000\u0000"+
		"\u0000\u0d7b\u0d7c\u0001\u0000\u0000\u0000\u0d7c\u00cd\u0001\u0000\u0000"+
		"\u0000\u0d7d\u0d7e\u0005f\u0000\u0000\u0d7e\u0d80\u0005\u02b0\u0000\u0000"+
		"\u0d7f\u0d81\u0007+\u0000\u0000\u0d80\u0d7f\u0001\u0000\u0000\u0000\u0d80"+
		"\u0d81\u0001\u0000\u0000\u0000\u0d81\u0d83\u0001\u0000\u0000\u0000\u0d82"+
		"\u0d84\u0005\u01da\u0000\u0000\u0d83\u0d82\u0001\u0000\u0000\u0000\u0d83"+
		"\u0d84\u0001\u0000\u0000\u0000\u0d84\u0d85\u0001\u0000\u0000\u0000\u0d85"+
		"\u0d86\u0005R\u0000\u0000\u0d86\u0d88\u0005\u0491\u0000\u0000\u0d87\u0d89"+
		"\u0007\u0006\u0000\u0000\u0d88\u0d87\u0001\u0000\u0000\u0000\u0d88\u0d89"+
		"\u0001\u0000\u0000\u0000\u0d89\u0d8a\u0001\u0000\u0000\u0000\u0d8a\u0d8b"+
		"\u0005W\u0000\u0000\u0d8b\u0d8c\u0005\u00ac\u0000\u0000\u0d8c\u0d90\u0003"+
		"\u022e\u0117\u0000\u0d8d\u0d8e\u0005\u001a\u0000\u0000\u0d8e\u0d8f\u0005"+
		"\u009a\u0000\u0000\u0d8f\u0d91\u0003\u023e\u011f\u0000\u0d90\u0d8d\u0001"+
		"\u0000\u0000\u0000\u0d90\u0d91\u0001\u0000\u0000\u0000\u0d91\u0d98\u0001"+
		"\u0000\u0000\u0000\u0d92\u0d93\u0005\u025b\u0000\u0000\u0d93\u0d94\u0005"+
		"\u01c0\u0000\u0000\u0d94\u0d95\u0005\u0014\u0000\u0000\u0d95\u0d96\u0005"+
		"\u047b\u0000\u0000\u0d96\u0d97\u0005\u0491\u0000\u0000\u0d97\u0d99\u0005"+
		"\u047a\u0000\u0000\u0d98\u0d92\u0001\u0000\u0000\u0000\u0d98\u0d99\u0001"+
		"\u0000\u0000\u0000\u0d99\u0d9e\u0001\u0000\u0000\u0000\u0d9a\u0d9b\u0005"+
		"N\u0000\u0000\u0d9b\u0d9c\u0003\u0256\u012b\u0000\u0d9c\u0d9d\u0007-\u0000"+
		"\u0000\u0d9d\u0d9f\u0001\u0000\u0000\u0000\u0d9e\u0d9a\u0001\u0000\u0000"+
		"\u0000\u0d9e\u0d9f\u0001\u0000\u0000\u0000\u0d9f\u0dab\u0001\u0000\u0000"+
		"\u0000\u0da0\u0da1\u0005\u0482\u0000\u0000\u0da1\u0da6\u0003\u00dcn\u0000"+
		"\u0da2\u0da3\u0005\u0484\u0000\u0000\u0da3\u0da5\u0003\u00dcn\u0000\u0da4"+
		"\u0da2\u0001\u0000\u0000\u0000\u0da5\u0da8\u0001\u0000\u0000\u0000\u0da6"+
		"\u0da4\u0001\u0000\u0000\u0000\u0da6\u0da7\u0001\u0000\u0000\u0000\u0da7"+
		"\u0da9\u0001\u0000\u0000\u0000\u0da8\u0da6\u0001\u0000\u0000\u0000\u0da9"+
		"\u0daa\u0005\u0483\u0000\u0000\u0daa\u0dac\u0001\u0000\u0000\u0000\u0dab"+
		"\u0da0\u0001\u0000\u0000\u0000\u0dab\u0dac\u0001\u0000\u0000\u0000\u0dac"+
		"\u0db6\u0001\u0000\u0000\u0000\u0dad\u0dae\u0005\u009a\u0000\u0000\u0dae"+
		"\u0db3\u0003\u00dam\u0000\u0daf\u0db0\u0005\u0484\u0000\u0000\u0db0\u0db2"+
		"\u0003\u00dam\u0000\u0db1\u0daf\u0001\u0000\u0000\u0000\u0db2\u0db5\u0001"+
		"\u0000\u0000\u0000\u0db3\u0db1\u0001\u0000\u0000\u0000\u0db3\u0db4\u0001"+
		"\u0000\u0000\u0000\u0db4\u0db7\u0001\u0000\u0000\u0000\u0db5\u0db3\u0001"+
		"\u0000\u0000\u0000\u0db6\u0dad\u0001\u0000\u0000\u0000\u0db6\u0db7\u0001"+
		"\u0000\u0000\u0000\u0db7\u00cf\u0001\u0000\u0000\u0000\u0db8\u0dba\u0005"+
		"\u008e\u0000\u0000\u0db9\u0dbb\u0007.\u0000\u0000\u0dba\u0db9\u0001\u0000"+
		"\u0000\u0000\u0dba\u0dbb\u0001\u0000\u0000\u0000\u0dbb\u0dbd\u0001\u0000"+
		"\u0000\u0000\u0dbc\u0dbe\u0005W\u0000\u0000\u0dbd\u0dbc\u0001\u0000\u0000"+
		"\u0000\u0dbd\u0dbe\u0001\u0000\u0000\u0000\u0dbe\u0dbf\u0001\u0000\u0000"+
		"\u0000\u0dbf\u0dc5\u0003\u022e\u0117\u0000\u0dc0\u0dc1\u0005\u0081\u0000"+
		"\u0000\u0dc1\u0dc2\u0005\u0482\u0000\u0000\u0dc2\u0dc3\u0003\u0272\u0139"+
		"\u0000\u0dc3\u0dc4\u0005\u0483\u0000\u0000\u0dc4\u0dc6\u0001\u0000\u0000"+
		"\u0000\u0dc5\u0dc0\u0001\u0000\u0000\u0000\u0dc5\u0dc6\u0001\u0000\u0000"+
		"\u0000\u0dc6\u0dd7\u0001\u0000\u0000\u0000\u0dc7\u0dc8\u0005\u0482\u0000"+
		"\u0000\u0dc8\u0dc9\u0003\u0272\u0139\u0000\u0dc9\u0dca\u0005\u0483\u0000"+
		"\u0000\u0dca\u0dcc\u0001\u0000\u0000\u0000\u0dcb\u0dc7\u0001\u0000\u0000"+
		"\u0000\u0dcb\u0dcc\u0001\u0000\u0000\u0000\u0dcc\u0dcd\u0001\u0000\u0000"+
		"\u0000\u0dcd\u0dd8\u0003\u00d8l\u0000\u0dce\u0dcf\u0005\u009a\u0000\u0000"+
		"\u0dcf\u0dd4\u0003\u00dam\u0000\u0dd0\u0dd1\u0005\u0484\u0000\u0000\u0dd1"+
		"\u0dd3\u0003\u00dam\u0000\u0dd2\u0dd0\u0001\u0000\u0000\u0000\u0dd3\u0dd6"+
		"\u0001\u0000\u0000\u0000\u0dd4\u0dd2\u0001\u0000\u0000\u0000\u0dd4\u0dd5"+
		"\u0001\u0000\u0000\u0000\u0dd5\u0dd8\u0001\u0000\u0000\u0000\u0dd6\u0dd4"+
		"\u0001\u0000\u0000\u0000\u0dd7\u0dcb\u0001\u0000\u0000\u0000\u0dd7\u0dce"+
		"\u0001\u0000\u0000\u0000\u0dd8\u00d1\u0001\u0000\u0000\u0000\u0dd9\u0ddb"+
		"\u0003\u0104\u0082\u0000\u0dda\u0ddc\u0003\u00deo\u0000\u0ddb\u0dda\u0001"+
		"\u0000\u0000\u0000\u0ddb\u0ddc\u0001\u0000\u0000\u0000\u0ddc\u0e18\u0001"+
		"\u0000\u0000\u0000\u0ddd\u0ddf\u0003\u0100\u0080\u0000\u0dde\u0de0\u0003"+
		"\u00deo\u0000\u0ddf\u0dde\u0001\u0000\u0000\u0000\u0ddf\u0de0\u0001\u0000"+
		"\u0000\u0000\u0de0\u0e18\u0001\u0000\u0000\u0000\u0de1\u0de3\u0003\u0106"+
		"\u0083\u0000\u0de2\u0de4\u0003\u010a\u0085\u0000\u0de3\u0de2\u0001\u0000"+
		"\u0000\u0000\u0de4\u0de5\u0001\u0000\u0000\u0000\u0de5\u0de3\u0001\u0000"+
		"\u0000\u0000\u0de5\u0de6\u0001\u0000\u0000\u0000\u0de6\u0def\u0001\u0000"+
		"\u0000\u0000\u0de7\u0de9\u0005\u00b4\u0000\u0000\u0de8\u0dea\u0007/\u0000"+
		"\u0000\u0de9\u0de8\u0001\u0000\u0000\u0000\u0de9\u0dea\u0001\u0000\u0000"+
		"\u0000\u0dea\u0ded\u0001\u0000\u0000\u0000\u0deb\u0dee\u0003\u0104\u0082"+
		"\u0000\u0dec\u0dee\u0003\u0100\u0080\u0000\u0ded\u0deb\u0001\u0000\u0000"+
		"\u0000\u0ded\u0dec\u0001\u0000\u0000\u0000\u0dee\u0df0\u0001\u0000\u0000"+
		"\u0000\u0def\u0de7\u0001\u0000\u0000\u0000\u0def\u0df0\u0001\u0000\u0000"+
		"\u0000\u0df0\u0df2\u0001\u0000\u0000\u0000\u0df1\u0df3\u0003\u00f0x\u0000"+
		"\u0df2\u0df1\u0001\u0000\u0000\u0000\u0df2\u0df3\u0001\u0000\u0000\u0000"+
		"\u0df3\u0df5\u0001\u0000\u0000\u0000\u0df4\u0df6\u0003\u012e\u0097\u0000"+
		"\u0df5\u0df4\u0001\u0000\u0000\u0000\u0df5\u0df6\u0001\u0000\u0000\u0000"+
		"\u0df6\u0df8\u0001\u0000\u0000\u0000\u0df7\u0df9\u0003\u00deo\u0000\u0df8"+
		"\u0df7\u0001\u0000\u0000\u0000\u0df8\u0df9\u0001\u0000\u0000\u0000\u0df9"+
		"\u0e18\u0001\u0000\u0000\u0000\u0dfa\u0dfc\u0003\u0102\u0081\u0000\u0dfb"+
		"\u0dfd\u0003\u0108\u0084\u0000\u0dfc\u0dfb\u0001\u0000\u0000\u0000\u0dfd"+
		"\u0dfe\u0001\u0000\u0000\u0000\u0dfe\u0dfc\u0001\u0000\u0000\u0000\u0dfe"+
		"\u0dff\u0001\u0000\u0000\u0000\u0dff\u0e05\u0001\u0000\u0000\u0000\u0e00"+
		"\u0e02\u0005\u00b4\u0000\u0000\u0e01\u0e03\u0007/\u0000\u0000\u0e02\u0e01"+
		"\u0001\u0000\u0000\u0000\u0e02\u0e03\u0001\u0000\u0000\u0000\u0e03\u0e04"+
		"\u0001\u0000\u0000\u0000\u0e04\u0e06\u0003\u0100\u0080\u0000\u0e05\u0e00"+
		"\u0001\u0000\u0000\u0000\u0e05\u0e06\u0001\u0000\u0000\u0000\u0e06\u0e08"+
		"\u0001\u0000\u0000\u0000\u0e07\u0e09\u0003\u00f0x\u0000\u0e08\u0e07\u0001"+
		"\u0000\u0000\u0000\u0e08\u0e09\u0001\u0000\u0000\u0000\u0e09\u0e0b\u0001"+
		"\u0000\u0000\u0000\u0e0a\u0e0c\u0003\u012e\u0097\u0000\u0e0b\u0e0a\u0001"+
		"\u0000\u0000\u0000\u0e0b\u0e0c\u0001\u0000\u0000\u0000\u0e0c\u0e0e\u0001"+
		"\u0000\u0000\u0000\u0e0d\u0e0f\u0003\u00deo\u0000\u0e0e\u0e0d\u0001\u0000"+
		"\u0000\u0000\u0e0e\u0e0f\u0001\u0000\u0000\u0000\u0e0f\u0e18\u0001\u0000"+
		"\u0000\u0000\u0e10\u0e13\u0003\u0106\u0083\u0000\u0e11\u0e12\u0005\u0484"+
		"\u0000\u0000\u0e12\u0e14\u0003\u010c\u0086\u0000\u0e13\u0e11\u0001\u0000"+
		"\u0000\u0000\u0e14\u0e15\u0001\u0000\u0000\u0000\u0e15\u0e13\u0001\u0000"+
		"\u0000\u0000\u0e15\u0e16\u0001\u0000\u0000\u0000\u0e16\u0e18\u0001\u0000"+
		"\u0000\u0000\u0e17\u0dd9\u0001\u0000\u0000\u0000\u0e17\u0ddd\u0001\u0000"+
		"\u0000\u0000\u0e17\u0de1\u0001\u0000\u0000\u0000\u0e17\u0dfa\u0001\u0000"+
		"\u0000\u0000\u0e17\u0e10\u0001\u0000\u0000\u0000\u0e18\u00d3\u0001\u0000"+
		"\u0000\u0000\u0e19\u0e1c\u0003\u00ecv\u0000\u0e1a\u0e1c\u0003\u00eew\u0000"+
		"\u0e1b\u0e19\u0001\u0000\u0000\u0000\u0e1b\u0e1a\u0001\u0000\u0000\u0000"+
		"\u0e1c\u00d5\u0001\u0000\u0000\u0000\u0e1d\u0e1e\u0005\u00bc\u0000\u0000"+
		"\u0e1e\u0e20\u0005\u0482\u0000\u0000\u0e1f\u0e21\u0003\u027a\u013d\u0000"+
		"\u0e20\u0e1f\u0001\u0000\u0000\u0000\u0e20\u0e21\u0001\u0000\u0000\u0000"+
		"\u0e21\u0e22\u0001\u0000\u0000\u0000\u0e22\u0e2b\u0005\u0483\u0000\u0000"+
		"\u0e23\u0e24\u0005\u0484\u0000\u0000\u0e24\u0e26\u0005\u0482\u0000\u0000"+
		"\u0e25\u0e27\u0003\u027a\u013d\u0000\u0e26\u0e25\u0001\u0000\u0000\u0000"+
		"\u0e26\u0e27\u0001\u0000\u0000\u0000\u0e27\u0e28\u0001\u0000\u0000\u0000"+
		"\u0e28\u0e2a\u0005\u0483\u0000\u0000\u0e29\u0e23\u0001\u0000\u0000\u0000"+
		"\u0e2a\u0e2d\u0001\u0000\u0000\u0000\u0e2b\u0e29\u0001\u0000\u0000\u0000"+
		"\u0e2b\u0e2c\u0001\u0000\u0000\u0000\u0e2c\u00d7\u0001\u0000\u0000\u0000"+
		"\u0e2d\u0e2b\u0001\u0000\u0000\u0000\u0e2e\u0e41\u0003\u00d2i\u0000\u0e2f"+
		"\u0e30\u00070\u0000\u0000\u0e30\u0e32\u0005\u0482\u0000\u0000\u0e31\u0e33"+
		"\u0003\u027a\u013d\u0000\u0e32\u0e31\u0001\u0000\u0000\u0000\u0e32\u0e33"+
		"\u0001\u0000\u0000\u0000\u0e33\u0e34\u0001\u0000\u0000\u0000\u0e34\u0e3d"+
		"\u0005\u0483\u0000\u0000\u0e35\u0e36\u0005\u0484\u0000\u0000\u0e36\u0e38"+
		"\u0005\u0482\u0000\u0000\u0e37\u0e39\u0003\u027a\u013d\u0000\u0e38\u0e37"+
		"\u0001\u0000\u0000\u0000\u0e38\u0e39\u0001\u0000\u0000\u0000\u0e39\u0e3a"+
		"\u0001\u0000\u0000\u0000\u0e3a\u0e3c\u0005\u0483\u0000\u0000\u0e3b\u0e35"+
		"\u0001\u0000\u0000\u0000\u0e3c\u0e3f\u0001\u0000\u0000\u0000\u0e3d\u0e3b"+
		"\u0001\u0000\u0000\u0000\u0e3d\u0e3e\u0001\u0000\u0000\u0000\u0e3e\u0e41"+
		"\u0001\u0000\u0000\u0000\u0e3f\u0e3d\u0001\u0000\u0000\u0000\u0e40\u0e2e"+
		"\u0001\u0000\u0000\u0000\u0e40\u0e2f\u0001\u0000\u0000\u0000\u0e41\u00d9"+
		"\u0001\u0000\u0000\u0000\u0e42\u0e43\u0003\u0232\u0119\u0000\u0e43\u0e46"+
		"\u0005\u0479\u0000\u0000\u0e44\u0e47\u0003\u02ba\u015d\u0000\u0e45\u0e47"+
		"\u0005+\u0000\u0000\u0e46\u0e44\u0001\u0000\u0000\u0000\u0e46\u0e45\u0001"+
		"\u0000\u0000\u0000\u0e47\u00db\u0001\u0000\u0000\u0000\u0e48\u0e4b\u0003"+
		"\u0250\u0128\u0000\u0e49\u0e4b\u0005\u049c\u0000\u0000\u0e4a\u0e48\u0001"+
		"\u0000\u0000\u0000\u0e4a\u0e49\u0001\u0000\u0000\u0000\u0e4b\u00dd\u0001"+
		"\u0000\u0000\u0000\u0e4c\u0e4d\u0005A\u0000\u0000\u0e4d\u0e53\u0005\u00b8"+
		"\u0000\u0000\u0e4e\u0e4f\u0005g\u0000\u0000\u0e4f\u0e50\u0005P\u0000\u0000"+
		"\u0e50\u0e51\u0005\u0264\u0000\u0000\u0e51\u0e53\u0005\u0200\u0000\u0000"+
		"\u0e52\u0e4c\u0001\u0000\u0000\u0000\u0e52\u0e4e\u0001\u0000\u0000\u0000"+
		"\u0e53\u0e55\u0001\u0000\u0000\u0000\u0e54\u0e56\u0003\u0290\u0148\u0000"+
		"\u0e55\u0e54\u0001\u0000\u0000\u0000\u0e55\u0e56\u0001\u0000\u0000\u0000"+
		"\u0e56\u00df\u0001\u0000\u0000\u0000\u0e57\u0e59\u0005-\u0000\u0000\u0e58"+
		"\u0e5a\u0005j\u0000\u0000\u0e59\u0e58\u0001\u0000\u0000\u0000\u0e59\u0e5a"+
		"\u0001\u0000\u0000\u0000\u0e5a\u0e5c\u0001\u0000\u0000\u0000\u0e5b\u0e5d"+
		"\u0005\u023a\u0000\u0000\u0e5c\u0e5b\u0001\u0000\u0000\u0000\u0e5c\u0e5d"+
		"\u0001\u0000\u0000\u0000\u0e5d\u0e5f\u0001\u0000\u0000\u0000\u0e5e\u0e60"+
		"\u0005N\u0000\u0000\u0e5f\u0e5e\u0001\u0000\u0000\u0000\u0e5f\u0e60\u0001"+
		"\u0000\u0000\u0000\u0e60\u0e61\u0001\u0000\u0000\u0000\u0e61\u0e62\u0005"+
		"D\u0000\u0000\u0e62\u0e68\u0003\u022e\u0117\u0000\u0e63\u0e64\u0005\u0081"+
		"\u0000\u0000\u0e64\u0e65\u0005\u0482\u0000\u0000\u0e65\u0e66\u0003\u0272"+
		"\u0139\u0000\u0e66\u0e67\u0005\u0483\u0000\u0000\u0e67\u0e69\u0001\u0000"+
		"\u0000\u0000\u0e68\u0e63\u0001\u0000\u0000\u0000\u0e68\u0e69\u0001\u0000"+
		"\u0000\u0000\u0e69\u0e6c\u0001\u0000\u0000\u0000\u0e6a\u0e6b\u0005\u00be"+
		"\u0000\u0000\u0e6b\u0e6d\u0003\u02ba\u015d\u0000\u0e6c\u0e6a\u0001\u0000"+
		"\u0000\u0000\u0e6c\u0e6d\u0001\u0000\u0000\u0000\u0e6d\u0e6f\u0001\u0000"+
		"\u0000\u0000\u0e6e\u0e70\u0003\u00f0x\u0000\u0e6f\u0e6e\u0001\u0000\u0000"+
		"\u0000\u0e6f\u0e70\u0001\u0000\u0000\u0000\u0e70\u0e73\u0001\u0000\u0000"+
		"\u0000\u0e71\u0e72\u0005c\u0000\u0000\u0e72\u0e74\u0003\u0130\u0098\u0000"+
		"\u0e73\u0e71\u0001\u0000\u0000\u0000\u0e73\u0e74\u0001\u0000\u0000\u0000"+
		"\u0e74\u00e1\u0001\u0000\u0000\u0000\u0e75\u0e77\u0005-\u0000\u0000\u0e76"+
		"\u0e78\u0005j\u0000\u0000\u0e77\u0e76\u0001\u0000\u0000\u0000\u0e77\u0e78"+
		"\u0001\u0000\u0000\u0000\u0e78\u0e7a\u0001\u0000\u0000\u0000\u0e79\u0e7b"+
		"\u0005\u023a\u0000\u0000\u0e7a\u0e79\u0001\u0000\u0000\u0000\u0e7a\u0e7b"+
		"\u0001\u0000\u0000\u0000\u0e7b\u0e7d\u0001\u0000\u0000\u0000\u0e7c\u0e7e"+
		"\u0005N\u0000\u0000\u0e7d\u0e7c\u0001\u0000\u0000\u0000\u0e7d\u0e7e\u0001"+
		"\u0000\u0000\u0000\u0e7e\u0ea6\u0001\u0000\u0000\u0000\u0e7f\u0e82\u0003"+
		"\u022e\u0117\u0000\u0e80\u0e81\u0005\u0481\u0000\u0000\u0e81\u0e83\u0005"+
		"\u0472\u0000\u0000\u0e82\u0e80\u0001\u0000\u0000\u0000\u0e82\u0e83\u0001"+
		"\u0000\u0000\u0000\u0e83\u0e8c\u0001\u0000\u0000\u0000\u0e84\u0e85\u0005"+
		"\u0484\u0000\u0000\u0e85\u0e88\u0003\u022e\u0117\u0000\u0e86\u0e87\u0005"+
		"\u0481\u0000\u0000\u0e87\u0e89\u0005\u0472\u0000\u0000\u0e88\u0e86\u0001"+
		"\u0000\u0000\u0000\u0e88\u0e89\u0001\u0000\u0000\u0000\u0e89\u0e8b\u0001"+
		"\u0000\u0000\u0000\u0e8a\u0e84\u0001\u0000\u0000\u0000\u0e8b\u0e8e\u0001"+
		"\u0000\u0000\u0000\u0e8c\u0e8a\u0001\u0000\u0000\u0000\u0e8c\u0e8d\u0001"+
		"\u0000\u0000\u0000\u0e8d\u0e8f\u0001\u0000\u0000\u0000\u0e8e\u0e8c\u0001"+
		"\u0000\u0000\u0000\u0e8f\u0e90\u0005D\u0000\u0000\u0e90\u0e91\u0003\u00f4"+
		"z\u0000\u0e91\u0ea7\u0001\u0000\u0000\u0000\u0e92\u0e93\u0005D\u0000\u0000"+
		"\u0e93\u0e96\u0003\u022e\u0117\u0000\u0e94\u0e95\u0005\u0481\u0000\u0000"+
		"\u0e95\u0e97\u0005\u0472\u0000\u0000\u0e96\u0e94\u0001\u0000\u0000\u0000"+
		"\u0e96\u0e97\u0001\u0000\u0000\u0000\u0e97\u0ea0\u0001\u0000\u0000\u0000"+
		"\u0e98\u0e99\u0005\u0484\u0000\u0000\u0e99\u0e9c\u0003\u022e\u0117\u0000"+
		"\u0e9a\u0e9b\u0005\u0481\u0000\u0000\u0e9b\u0e9d\u0005\u0472\u0000\u0000"+
		"\u0e9c\u0e9a\u0001\u0000\u0000\u0000\u0e9c\u0e9d\u0001\u0000\u0000\u0000"+
		"\u0e9d\u0e9f\u0001\u0000\u0000\u0000\u0e9e\u0e98\u0001\u0000\u0000\u0000"+
		"\u0e9f\u0ea2\u0001\u0000\u0000\u0000\u0ea0\u0e9e\u0001\u0000\u0000\u0000"+
		"\u0ea0\u0ea1\u0001\u0000\u0000\u0000\u0ea1\u0ea3\u0001\u0000\u0000\u0000"+
		"\u0ea2\u0ea0\u0001\u0000\u0000\u0000\u0ea3\u0ea4\u0005\u00bb\u0000\u0000"+
		"\u0ea4\u0ea5\u0003\u00f4z\u0000\u0ea5\u0ea7\u0001\u0000\u0000\u0000\u0ea6"+
		"\u0e7f\u0001\u0000\u0000\u0000\u0ea6\u0e92\u0001\u0000\u0000\u0000\u0ea7"+
		"\u0eaa\u0001\u0000\u0000\u0000\u0ea8\u0ea9\u0005\u00be\u0000\u0000\u0ea9"+
		"\u0eab\u0003\u02ba\u015d\u0000\u0eaa\u0ea8\u0001\u0000\u0000\u0000\u0eaa"+
		"\u0eab\u0001\u0000\u0000\u0000\u0eab\u00e3\u0001\u0000\u0000\u0000\u0eac"+
		"\u0ead\u0005\u01ba\u0000\u0000\u0ead\u0eae\u0003\u022e\u0117\u0000\u0eae"+
		"\u0eb3\u0005\u021c\u0000\u0000\u0eaf\u0eb1\u0005\f\u0000\u0000\u0eb0\u0eaf"+
		"\u0001\u0000\u0000\u0000\u0eb0\u0eb1\u0001\u0000\u0000\u0000\u0eb1\u0eb2"+
		"\u0001\u0000\u0000\u0000\u0eb2\u0eb4\u0003\u0250\u0128\u0000\u0eb3\u0eb0"+
		"\u0001\u0000\u0000\u0000\u0eb3\u0eb4\u0001\u0000\u0000\u0000\u0eb4\u00e5"+
		"\u0001\u0000\u0000\u0000\u0eb5\u0eb6\u0005\u01ba\u0000\u0000\u0eb6\u0eb7"+
		"\u0003\u022e\u0117\u0000\u0eb7\u0eb8\u0005\u0087\u0000\u0000\u0eb8\u0ebf"+
		"\u0003\u0250\u0128\u0000\u0eb9\u0eba\u0003\u02c2\u0161\u0000\u0eba\u0ebb"+
		"\u0005\u0482\u0000\u0000\u0ebb\u0ebc\u0003\u027c\u013e\u0000\u0ebc\u0ebd"+
		"\u0005\u0483\u0000\u0000\u0ebd\u0ec0\u0001\u0000\u0000\u0000\u0ebe\u0ec0"+
		"\u00071\u0000\u0000\u0ebf\u0eb9\u0001\u0000\u0000\u0000\u0ebf\u0ebe\u0001"+
		"\u0000\u0000\u0000\u0ec0\u0ec3\u0001\u0000\u0000\u0000\u0ec1\u0ec2\u0005"+
		"\u00be\u0000\u0000\u0ec2\u0ec4\u0003\u02ba\u015d\u0000\u0ec3\u0ec1\u0001"+
		"\u0000\u0000\u0000\u0ec3\u0ec4\u0001\u0000\u0000\u0000\u0ec4\u0ec7\u0001"+
		"\u0000\u0000\u0000\u0ec5\u0ec6\u0005c\u0000\u0000\u0ec6\u0ec8\u0003\u0130"+
		"\u0098\u0000\u0ec7\u0ec5\u0001\u0000\u0000\u0000\u0ec7\u0ec8\u0001\u0000"+
		"\u0000\u0000\u0ec8\u00e7\u0001\u0000\u0000\u0000\u0ec9\u0eca\u0005\u01ba"+
		"\u0000\u0000\u0eca\u0ecb\u0003\u022e\u0117\u0000\u0ecb\u0ecc\u0005\u0087"+
		"\u0000\u0000\u0ecc\u0ecf\u00072\u0000\u0000\u0ecd\u0ece\u0005\u00be\u0000"+
		"\u0000\u0ece\u0ed0\u0003\u02ba\u015d\u0000\u0ecf\u0ecd\u0001\u0000\u0000"+
		"\u0000\u0ecf\u0ed0\u0001\u0000\u0000\u0000\u0ed0\u0ed3\u0001\u0000\u0000"+
		"\u0000\u0ed1\u0ed2\u0005c\u0000\u0000\u0ed2\u0ed4\u0003\u0130\u0098\u0000"+
		"\u0ed3\u0ed1\u0001\u0000\u0000\u0000\u0ed3\u0ed4\u0001\u0000\u0000\u0000"+
		"\u0ed4\u00e9\u0001\u0000\u0000\u0000\u0ed5\u0ed6\u0005\u01ba\u0000\u0000"+
		"\u0ed6\u0ed7\u0003\u022e\u0117\u0000\u0ed7\u0ed8\u0005\u0169\u0000\u0000"+
		"\u0ed8\u00eb\u0001\u0000\u0000\u0000";
	private static final String _serializedATNSegment2 =
		"\u0ed9\u0edb\u0005\u00b8\u0000\u0000\u0eda\u0edc\u0005j\u0000\u0000\u0edb"+
		"\u0eda\u0001\u0000\u0000\u0000\u0edb\u0edc\u0001\u0000\u0000\u0000\u0edc"+
		"\u0ede\u0001\u0000\u0000\u0000\u0edd\u0edf\u0005N\u0000\u0000\u0ede\u0edd"+
		"\u0001\u0000\u0000\u0000\u0ede\u0edf\u0001\u0000\u0000\u0000\u0edf\u0ee0"+
		"\u0001\u0000\u0000\u0000\u0ee0\u0ee5\u0003\u022e\u0117\u0000\u0ee1\u0ee3"+
		"\u0005\f\u0000\u0000\u0ee2\u0ee1\u0001\u0000\u0000\u0000\u0ee2\u0ee3\u0001"+
		"\u0000\u0000\u0000\u0ee3\u0ee4\u0001\u0000\u0000\u0000\u0ee4\u0ee6\u0003"+
		"\u0250\u0128\u0000\u0ee5\u0ee2\u0001\u0000\u0000\u0000\u0ee5\u0ee6\u0001"+
		"\u0000\u0000\u0000\u0ee6\u0ee7\u0001\u0000\u0000\u0000\u0ee7\u0ee8\u0005"+
		"\u009a\u0000\u0000\u0ee8\u0eed\u0003\u00dam\u0000\u0ee9\u0eea\u0005\u0484"+
		"\u0000\u0000\u0eea\u0eec\u0003\u00dam\u0000\u0eeb\u0ee9\u0001\u0000\u0000"+
		"\u0000\u0eec\u0eef\u0001\u0000\u0000\u0000\u0eed\u0eeb\u0001\u0000\u0000"+
		"\u0000\u0eed\u0eee\u0001\u0000\u0000\u0000\u0eee\u0ef2\u0001\u0000\u0000"+
		"\u0000\u0eef\u0eed\u0001\u0000\u0000\u0000\u0ef0\u0ef1\u0005\u00be\u0000"+
		"\u0000\u0ef1\u0ef3\u0003\u02ba\u015d\u0000\u0ef2\u0ef0\u0001\u0000\u0000"+
		"\u0000\u0ef2\u0ef3\u0001\u0000\u0000\u0000\u0ef3\u0ef5\u0001\u0000\u0000"+
		"\u0000\u0ef4\u0ef6\u0003\u00f0x\u0000\u0ef5\u0ef4\u0001\u0000\u0000\u0000"+
		"\u0ef5\u0ef6\u0001\u0000\u0000\u0000\u0ef6\u0ef8\u0001\u0000\u0000\u0000"+
		"\u0ef7\u0ef9\u0003\u012e\u0097\u0000\u0ef8\u0ef7\u0001\u0000\u0000\u0000"+
		"\u0ef8\u0ef9\u0001\u0000\u0000\u0000\u0ef9\u00ed\u0001\u0000\u0000\u0000"+
		"\u0efa\u0efc\u0005\u00b8\u0000\u0000\u0efb\u0efd\u0005j\u0000\u0000\u0efc"+
		"\u0efb\u0001\u0000\u0000\u0000\u0efc\u0efd\u0001\u0000\u0000\u0000\u0efd"+
		"\u0eff\u0001\u0000\u0000\u0000\u0efe\u0f00\u0005N\u0000\u0000\u0eff\u0efe"+
		"\u0001\u0000\u0000\u0000\u0eff\u0f00\u0001\u0000\u0000\u0000\u0f00\u0f01"+
		"\u0001\u0000\u0000\u0000\u0f01\u0f02\u0003\u00f4z\u0000\u0f02\u0f03\u0005"+
		"\u009a\u0000\u0000\u0f03\u0f08\u0003\u00dam\u0000\u0f04\u0f05\u0005\u0484"+
		"\u0000\u0000\u0f05\u0f07\u0003\u00dam\u0000\u0f06\u0f04\u0001\u0000\u0000"+
		"\u0000\u0f07\u0f0a\u0001\u0000\u0000\u0000\u0f08\u0f06\u0001\u0000\u0000"+
		"\u0000\u0f08\u0f09\u0001\u0000\u0000\u0000\u0f09\u0f0d\u0001\u0000\u0000"+
		"\u0000\u0f0a\u0f08\u0001\u0000\u0000\u0000\u0f0b\u0f0c\u0005\u00be\u0000"+
		"\u0000\u0f0c\u0f0e\u0003\u02ba\u015d\u0000\u0f0d\u0f0b\u0001\u0000\u0000"+
		"\u0000\u0f0d\u0f0e\u0001\u0000\u0000\u0000\u0f0e\u00ef\u0001\u0000\u0000"+
		"\u0000\u0f0f\u0f10\u0005|\u0000\u0000\u0f10\u0f11\u0005\u0014\u0000\u0000"+
		"\u0f11\u0f16\u0003\u00f2y\u0000\u0f12\u0f13\u0005\u0484\u0000\u0000\u0f13"+
		"\u0f15\u0003\u00f2y\u0000\u0f14\u0f12\u0001\u0000\u0000\u0000\u0f15\u0f18"+
		"\u0001\u0000\u0000\u0000\u0f16\u0f14\u0001\u0000\u0000\u0000\u0f16\u0f17"+
		"\u0001\u0000\u0000\u0000\u0f17\u00f1\u0001\u0000\u0000\u0000\u0f18\u0f16"+
		"\u0001\u0000\u0000\u0000\u0f19\u0f1b\u0003\u02ba\u015d\u0000\u0f1a\u0f1c"+
		"\u00073\u0000\u0000\u0f1b\u0f1a\u0001\u0000\u0000\u0000\u0f1b\u0f1c\u0001"+
		"\u0000\u0000\u0000\u0f1c\u00f3\u0001\u0000\u0000\u0000\u0f1d\u0f22\u0003"+
		"\u00f6{\u0000\u0f1e\u0f1f\u0005\u0484\u0000\u0000\u0f1f\u0f21\u0003\u00f6"+
		"{\u0000\u0f20\u0f1e\u0001\u0000\u0000\u0000\u0f21\u0f24\u0001\u0000\u0000"+
		"\u0000\u0f22\u0f20\u0001\u0000\u0000\u0000\u0f22\u0f23\u0001\u0000\u0000"+
		"\u0000\u0f23\u00f5\u0001\u0000\u0000\u0000\u0f24\u0f22\u0001\u0000\u0000"+
		"\u0000\u0f25\u0f29\u0003\u00f8|\u0000\u0f26\u0f28\u0003\u00fe\u007f\u0000"+
		"\u0f27\u0f26\u0001\u0000\u0000\u0000\u0f28\u0f2b\u0001\u0000\u0000\u0000"+
		"\u0f29\u0f27\u0001\u0000\u0000\u0000\u0f29\u0f2a\u0001\u0000\u0000\u0000"+
		"\u0f2a\u0f38\u0001\u0000\u0000\u0000\u0f2b\u0f29\u0001\u0000\u0000\u0000"+
		"\u0f2c\u0f2d\u0005\u0482\u0000\u0000\u0f2d\u0f31\u0003\u00f8|\u0000\u0f2e"+
		"\u0f30\u0003\u00fe\u007f\u0000\u0f2f\u0f2e\u0001\u0000\u0000\u0000\u0f30"+
		"\u0f33\u0001\u0000\u0000\u0000\u0f31\u0f2f\u0001\u0000\u0000\u0000\u0f31"+
		"\u0f32\u0001\u0000\u0000\u0000\u0f32\u0f34\u0001\u0000\u0000\u0000\u0f33"+
		"\u0f31\u0001\u0000\u0000\u0000\u0f34\u0f35\u0005\u0483\u0000\u0000\u0f35"+
		"\u0f38\u0001\u0000\u0000\u0000\u0f36\u0f38\u0003\u010e\u0087\u0000\u0f37"+
		"\u0f25\u0001\u0000\u0000\u0000\u0f37\u0f2c\u0001\u0000\u0000\u0000\u0f37"+
		"\u0f36\u0001\u0000\u0000\u0000\u0f38\u00f7\u0001\u0000\u0000\u0000\u0f39"+
		"\u0f3f\u0003\u022e\u0117\u0000\u0f3a\u0f3b\u0005\u0081\u0000\u0000\u0f3b"+
		"\u0f3c\u0005\u0482\u0000\u0000\u0f3c\u0f3d\u0003\u0272\u0139\u0000\u0f3d"+
		"\u0f3e\u0005\u0483\u0000\u0000\u0f3e\u0f40\u0001\u0000\u0000\u0000\u0f3f"+
		"\u0f3a\u0001\u0000\u0000\u0000\u0f3f\u0f40\u0001\u0000\u0000\u0000\u0f40"+
		"\u0f45\u0001\u0000\u0000\u0000\u0f41\u0f43\u0005\f\u0000\u0000\u0f42\u0f41"+
		"\u0001\u0000\u0000\u0000\u0f42\u0f43\u0001\u0000\u0000\u0000\u0f43\u0f44"+
		"\u0001\u0000\u0000\u0000\u0f44\u0f46\u0003\u0250\u0128\u0000\u0f45\u0f42"+
		"\u0001\u0000\u0000\u0000\u0f45\u0f46\u0001\u0000\u0000\u0000\u0f46\u0f4f"+
		"\u0001\u0000\u0000\u0000\u0f47\u0f4c\u0003\u00fa}\u0000\u0f48\u0f49\u0005"+
		"\u0484\u0000\u0000\u0f49\u0f4b\u0003\u00fa}\u0000\u0f4a\u0f48\u0001\u0000"+
		"\u0000\u0000\u0f4b\u0f4e\u0001\u0000\u0000\u0000\u0f4c\u0f4a\u0001\u0000"+
		"\u0000\u0000\u0f4c\u0f4d\u0001\u0000\u0000\u0000\u0f4d\u0f50\u0001\u0000"+
		"\u0000\u0000\u0f4e\u0f4c\u0001\u0000\u0000\u0000\u0f4f\u0f47\u0001\u0000"+
		"\u0000\u0000\u0f4f\u0f50\u0001\u0000\u0000\u0000\u0f50\u0f62\u0001\u0000"+
		"\u0000\u0000\u0f51\u0f57\u0003\u00d2i\u0000\u0f52\u0f53\u0005\u0482\u0000"+
		"\u0000\u0f53\u0f54\u0003\u00d2i\u0000\u0f54\u0f55\u0005\u0483\u0000\u0000"+
		"\u0f55\u0f57\u0001\u0000\u0000\u0000\u0f56\u0f51\u0001\u0000\u0000\u0000"+
		"\u0f56\u0f52\u0001\u0000\u0000\u0000\u0f57\u0f59\u0001\u0000\u0000\u0000"+
		"\u0f58\u0f5a\u0005\f\u0000\u0000\u0f59\u0f58\u0001\u0000\u0000\u0000\u0f59"+
		"\u0f5a\u0001\u0000\u0000\u0000\u0f5a\u0f5b\u0001\u0000\u0000\u0000\u0f5b"+
		"\u0f5c\u0003\u0250\u0128\u0000\u0f5c\u0f62\u0001\u0000\u0000\u0000\u0f5d"+
		"\u0f5e\u0005\u0482\u0000\u0000\u0f5e\u0f5f\u0003\u00f4z\u0000\u0f5f\u0f60"+
		"\u0005\u0483\u0000\u0000\u0f60\u0f62\u0001\u0000\u0000\u0000\u0f61\u0f39"+
		"\u0001\u0000\u0000\u0000\u0f61\u0f56\u0001\u0000\u0000\u0000\u0f61\u0f5d"+
		"\u0001\u0000\u0000\u0000\u0f62\u00f9\u0001\u0000\u0000\u0000\u0f63\u0f64"+
		"\u00074\u0000\u0000\u0f64\u0f67\u0007\u0017\u0000\u0000\u0f65\u0f66\u0005"+
		"A\u0000\u0000\u0f66\u0f68\u0003\u00fc~\u0000\u0f67\u0f65\u0001\u0000\u0000"+
		"\u0000\u0f67\u0f68\u0001\u0000\u0000\u0000\u0f68\u0f69\u0001\u0000\u0000"+
		"\u0000\u0f69\u0f6a\u0005\u0482\u0000\u0000\u0f6a\u0f6b\u0003\u0272\u0139"+
		"\u0000\u0f6b\u0f6c\u0005\u0483\u0000\u0000\u0f6c\u00fb\u0001\u0000\u0000"+
		"\u0000\u0f6d\u0f73\u0005Z\u0000\u0000\u0f6e\u0f6f\u0005|\u0000\u0000\u0f6f"+
		"\u0f73\u0005\u0014\u0000\u0000\u0f70\u0f71\u0005I\u0000\u0000\u0f71\u0f73"+
		"\u0005\u0014\u0000\u0000\u0f72\u0f6d\u0001\u0000\u0000\u0000\u0f72\u0f6e"+
		"\u0001\u0000\u0000\u0000\u0f72\u0f70\u0001\u0000\u0000\u0000\u0f73\u00fd"+
		"\u0001\u0000\u0000\u0000\u0f74\u0f76\u00075\u0000\u0000\u0f75\u0f74\u0001"+
		"\u0000\u0000\u0000\u0f75\u0f76\u0001\u0000\u0000\u0000\u0f76\u0f77\u0001"+
		"\u0000\u0000\u0000\u0f77\u0f79\u0005Z\u0000\u0000\u0f78\u0f7a\u0005^\u0000"+
		"\u0000\u0f79\u0f78\u0001\u0000\u0000\u0000\u0f79\u0f7a\u0001\u0000\u0000"+
		"\u0000\u0f7a\u0f7b\u0001\u0000\u0000\u0000\u0f7b\u0f83\u0003\u00f8|\u0000"+
		"\u0f7c\u0f7d\u0005v\u0000\u0000\u0f7d\u0f84\u0003\u02ba\u015d\u0000\u0f7e"+
		"\u0f7f\u0005\u00bb\u0000\u0000\u0f7f\u0f80\u0005\u0482\u0000\u0000\u0f80"+
		"\u0f81\u0003\u0272\u0139\u0000\u0f81\u0f82\u0005\u0483\u0000\u0000\u0f82"+
		"\u0f84\u0001\u0000\u0000\u0000\u0f83\u0f7c\u0001\u0000\u0000\u0000\u0f83"+
		"\u0f7e\u0001\u0000\u0000\u0000\u0f83\u0f84\u0001\u0000\u0000\u0000\u0f84"+
		"\u0fa7\u0001\u0000\u0000\u0000\u0f85\u0f86\u0005\u00ab\u0000\u0000\u0f86"+
		"\u0f89\u0003\u00f8|\u0000\u0f87\u0f88\u0005v\u0000\u0000\u0f88\u0f8a\u0003"+
		"\u02ba\u015d\u0000\u0f89\u0f87\u0001\u0000\u0000\u0000\u0f89\u0f8a\u0001"+
		"\u0000\u0000\u0000\u0f8a\u0fa7\u0001\u0000\u0000\u0000\u0f8b\u0f8d\u0007"+
		"6\u0000\u0000\u0f8c\u0f8e\u0005~\u0000\u0000\u0f8d\u0f8c\u0001\u0000\u0000"+
		"\u0000\u0f8d\u0f8e\u0001\u0000\u0000\u0000\u0f8e\u0f8f\u0001\u0000\u0000"+
		"\u0000\u0f8f\u0f91\u0005Z\u0000\u0000\u0f90\u0f92\u0005^\u0000\u0000\u0f91"+
		"\u0f90\u0001\u0000\u0000\u0000\u0f91\u0f92\u0001\u0000\u0000\u0000\u0f92"+
		"\u0f93\u0001\u0000\u0000\u0000\u0f93\u0f9b\u0003\u00f8|\u0000\u0f94\u0f95"+
		"\u0005v\u0000\u0000\u0f95\u0f9c\u0003\u02ba\u015d\u0000\u0f96\u0f97\u0005"+
		"\u00bb\u0000\u0000\u0f97\u0f98\u0005\u0482\u0000\u0000\u0f98\u0f99\u0003"+
		"\u0272\u0139\u0000\u0f99\u0f9a\u0005\u0483\u0000\u0000\u0f9a\u0f9c\u0001"+
		"\u0000\u0000\u0000\u0f9b\u0f94\u0001\u0000\u0000\u0000\u0f9b\u0f96\u0001"+
		"\u0000\u0000\u0000\u0f9c\u0fa7\u0001\u0000\u0000\u0000\u0f9d\u0fa2\u0005"+
		"q\u0000\u0000\u0f9e\u0fa0\u00076\u0000\u0000\u0f9f\u0fa1\u0005~\u0000"+
		"\u0000\u0fa0\u0f9f\u0001\u0000\u0000\u0000\u0fa0\u0fa1\u0001\u0000\u0000"+
		"\u0000\u0fa1\u0fa3\u0001\u0000\u0000\u0000\u0fa2\u0f9e\u0001\u0000\u0000"+
		"\u0000\u0fa2\u0fa3\u0001\u0000\u0000\u0000\u0fa3\u0fa4\u0001\u0000\u0000"+
		"\u0000\u0fa4\u0fa5\u0005Z\u0000\u0000\u0fa5\u0fa7\u0003\u00f8|\u0000\u0fa6"+
		"\u0f75\u0001\u0000\u0000\u0000\u0fa6\u0f85\u0001\u0000\u0000\u0000\u0fa6"+
		"\u0f8b\u0001\u0000\u0000\u0000\u0fa6\u0f9d\u0001\u0000\u0000\u0000\u0fa7"+
		"\u00ff\u0001\u0000\u0000\u0000\u0fa8\u0fa9\u0005\u0482\u0000\u0000\u0fa9"+
		"\u0faa\u0003\u0104\u0082\u0000\u0faa\u0fab\u0005\u0483\u0000\u0000\u0fab"+
		"\u0fb1\u0001\u0000\u0000\u0000\u0fac\u0fad\u0005\u0482\u0000\u0000\u0fad"+
		"\u0fae\u0003\u0100\u0080\u0000\u0fae\u0faf\u0005\u0483\u0000\u0000\u0faf"+
		"\u0fb1\u0001\u0000\u0000\u0000\u0fb0\u0fa8\u0001\u0000\u0000\u0000\u0fb0"+
		"\u0fac\u0001\u0000\u0000\u0000\u0fb1\u0101\u0001\u0000\u0000\u0000\u0fb2"+
		"\u0fb3\u0005\u0482\u0000\u0000\u0fb3\u0fb4\u0003\u0106\u0083\u0000\u0fb4"+
		"\u0fb5\u0005\u0483\u0000\u0000\u0fb5\u0fbb\u0001\u0000\u0000\u0000\u0fb6"+
		"\u0fb7\u0005\u0482\u0000\u0000\u0fb7\u0fb8\u0003\u0102\u0081\u0000\u0fb8"+
		"\u0fb9\u0005\u0483\u0000\u0000\u0fb9\u0fbb\u0001\u0000\u0000\u0000\u0fba"+
		"\u0fb2\u0001\u0000\u0000\u0000\u0fba\u0fb6\u0001\u0000\u0000\u0000\u0fbb"+
		"\u0103\u0001\u0000\u0000\u0000\u0fbc\u0fc0\u0005\u0099\u0000\u0000\u0fbd"+
		"\u0fbf\u0003\u0118\u008c\u0000\u0fbe\u0fbd\u0001\u0000\u0000\u0000\u0fbf"+
		"\u0fc2\u0001\u0000\u0000\u0000\u0fc0\u0fbe\u0001\u0000\u0000\u0000\u0fc0"+
		"\u0fc1\u0001\u0000\u0000\u0000\u0fc1\u0fc3\u0001\u0000\u0000\u0000\u0fc2"+
		"\u0fc0\u0001\u0000\u0000\u0000\u0fc3\u0fc5\u0003\u011a\u008d\u0000\u0fc4"+
		"\u0fc6\u0003\u011e\u008f\u0000\u0fc5\u0fc4\u0001\u0000\u0000\u0000\u0fc5"+
		"\u0fc6\u0001\u0000\u0000\u0000\u0fc6\u0fc8\u0001\u0000\u0000\u0000\u0fc7"+
		"\u0fc9\u0003\u0124\u0092\u0000\u0fc8\u0fc7\u0001\u0000\u0000\u0000\u0fc8"+
		"\u0fc9\u0001\u0000\u0000\u0000\u0fc9\u0fcb\u0001\u0000\u0000\u0000\u0fca"+
		"\u0fcc\u0003\u0126\u0093\u0000\u0fcb\u0fca\u0001\u0000\u0000\u0000\u0fcb"+
		"\u0fcc\u0001\u0000\u0000\u0000\u0fcc\u0fce\u0001\u0000\u0000\u0000\u0fcd"+
		"\u0fcf\u0003\u0128\u0094\u0000\u0fce\u0fcd\u0001\u0000\u0000\u0000\u0fce"+
		"\u0fcf\u0001\u0000\u0000\u0000\u0fcf\u0fd1\u0001\u0000\u0000\u0000\u0fd0"+
		"\u0fd2\u0003\u012a\u0095\u0000\u0fd1\u0fd0\u0001\u0000\u0000\u0000\u0fd1"+
		"\u0fd2\u0001\u0000\u0000\u0000\u0fd2\u0fd4\u0001\u0000\u0000\u0000\u0fd3"+
		"\u0fd5\u0003\u00f0x\u0000\u0fd4\u0fd3\u0001\u0000\u0000\u0000\u0fd4\u0fd5"+
		"\u0001\u0000\u0000\u0000\u0fd5\u0fd7\u0001\u0000\u0000\u0000\u0fd6\u0fd8"+
		"\u0003\u012e\u0097\u0000\u0fd7\u0fd6\u0001\u0000\u0000\u0000\u0fd7\u0fd8"+
		"\u0001\u0000\u0000\u0000\u0fd8\u0ff7\u0001\u0000\u0000\u0000\u0fd9\u0fdd"+
		"\u0005\u0099\u0000\u0000\u0fda\u0fdc\u0003\u0118\u008c\u0000\u0fdb\u0fda"+
		"\u0001\u0000\u0000\u0000\u0fdc\u0fdf\u0001\u0000\u0000\u0000\u0fdd\u0fdb"+
		"\u0001\u0000\u0000\u0000\u0fdd\u0fde\u0001\u0000\u0000\u0000\u0fde\u0fe0"+
		"\u0001\u0000\u0000\u0000\u0fdf\u0fdd\u0001\u0000\u0000\u0000\u0fe0\u0fe2"+
		"\u0003\u011a\u008d\u0000\u0fe1\u0fe3\u0003\u0124\u0092\u0000\u0fe2\u0fe1"+
		"\u0001\u0000\u0000\u0000\u0fe2\u0fe3\u0001\u0000\u0000\u0000\u0fe3\u0fe5"+
		"\u0001\u0000\u0000\u0000\u0fe4\u0fe6\u0003\u0126\u0093\u0000\u0fe5\u0fe4"+
		"\u0001\u0000\u0000\u0000\u0fe5\u0fe6\u0001\u0000\u0000\u0000\u0fe6\u0fe8"+
		"\u0001\u0000\u0000\u0000\u0fe7\u0fe9\u0003\u0128\u0094\u0000\u0fe8\u0fe7"+
		"\u0001\u0000\u0000\u0000\u0fe8\u0fe9\u0001\u0000\u0000\u0000\u0fe9\u0feb"+
		"\u0001\u0000\u0000\u0000\u0fea\u0fec\u0003\u012a\u0095\u0000\u0feb\u0fea"+
		"\u0001\u0000\u0000\u0000\u0feb\u0fec\u0001\u0000\u0000\u0000\u0fec\u0fee"+
		"\u0001\u0000\u0000\u0000\u0fed\u0fef\u0003\u00f0x\u0000\u0fee\u0fed\u0001"+
		"\u0000\u0000\u0000\u0fee\u0fef\u0001\u0000\u0000\u0000\u0fef\u0ff1\u0001"+
		"\u0000\u0000\u0000\u0ff0\u0ff2\u0003\u012e\u0097\u0000\u0ff1\u0ff0\u0001"+
		"\u0000\u0000\u0000\u0ff1\u0ff2\u0001\u0000\u0000\u0000\u0ff2\u0ff4\u0001"+
		"\u0000\u0000\u0000\u0ff3\u0ff5\u0003\u011e\u008f\u0000\u0ff4\u0ff3\u0001"+
		"\u0000\u0000\u0000\u0ff4\u0ff5\u0001\u0000\u0000\u0000\u0ff5\u0ff7\u0001"+
		"\u0000\u0000\u0000\u0ff6\u0fbc\u0001\u0000\u0000\u0000\u0ff6\u0fd9\u0001"+
		"\u0000\u0000\u0000\u0ff7\u0105\u0001\u0000\u0000\u0000\u0ff8\u0ffc\u0005"+
		"\u0099\u0000\u0000\u0ff9\u0ffb\u0003\u0118\u008c\u0000\u0ffa\u0ff9\u0001"+
		"\u0000\u0000\u0000\u0ffb\u0ffe\u0001\u0000\u0000\u0000\u0ffc\u0ffa\u0001"+
		"\u0000\u0000\u0000\u0ffc\u0ffd\u0001\u0000\u0000\u0000\u0ffd\u0fff\u0001"+
		"\u0000\u0000\u0000\u0ffe\u0ffc\u0001\u0000\u0000\u0000\u0fff\u1001\u0003"+
		"\u011a\u008d\u0000\u1000\u1002\u0003\u0124\u0092\u0000\u1001\u1000\u0001"+
		"\u0000\u0000\u0000\u1001\u1002\u0001\u0000\u0000\u0000\u1002\u1004\u0001"+
		"\u0000\u0000\u0000\u1003\u1005\u0003\u0126\u0093\u0000\u1004\u1003\u0001"+
		"\u0000\u0000\u0000\u1004\u1005\u0001\u0000\u0000\u0000\u1005\u1007\u0001"+
		"\u0000\u0000\u0000\u1006\u1008\u0003\u0128\u0094\u0000\u1007\u1006\u0001"+
		"\u0000\u0000\u0000\u1007\u1008\u0001\u0000\u0000\u0000\u1008\u100a\u0001"+
		"\u0000\u0000\u0000\u1009\u100b\u0003\u012a\u0095\u0000\u100a\u1009\u0001"+
		"\u0000\u0000\u0000\u100a\u100b\u0001\u0000\u0000\u0000\u100b\u100d\u0001"+
		"\u0000\u0000\u0000\u100c\u100e\u0003\u00f0x\u0000\u100d\u100c\u0001\u0000"+
		"\u0000\u0000\u100d\u100e\u0001\u0000\u0000\u0000\u100e\u1010\u0001\u0000"+
		"\u0000\u0000\u100f\u1011\u0003\u012e\u0097\u0000\u1010\u100f\u0001\u0000"+
		"\u0000\u0000\u1010\u1011\u0001\u0000\u0000\u0000\u1011\u0107\u0001\u0000"+
		"\u0000\u0000\u1012\u1014\u0005\u00b4\u0000\u0000\u1013\u1015\u0007/\u0000"+
		"\u0000\u1014\u1013\u0001\u0000\u0000\u0000\u1014\u1015\u0001\u0000\u0000"+
		"\u0000\u1015\u1016\u0001\u0000\u0000\u0000\u1016\u1017\u0003\u0102\u0081"+
		"\u0000\u1017\u0109\u0001\u0000\u0000\u0000\u1018\u101a\u0005\u00b4\u0000"+
		"\u0000\u1019\u101b\u0007/\u0000\u0000\u101a\u1019\u0001\u0000\u0000\u0000"+
		"\u101a\u101b\u0001\u0000\u0000\u0000\u101b\u101e\u0001\u0000\u0000\u0000"+
		"\u101c\u101f\u0003\u0106\u0083\u0000\u101d\u101f\u0003\u0102\u0081\u0000"+
		"\u101e\u101c\u0001\u0000\u0000\u0000\u101e\u101d\u0001\u0000\u0000\u0000"+
		"\u101f\u010b\u0001\u0000\u0000\u0000\u1020\u102f\u0005^\u0000\u0000\u1021"+
		"\u1030\u0003\u0106\u0083\u0000\u1022\u1030\u0003\u0102\u0081\u0000\u1023"+
		"\u1026\u0005\u0482\u0000\u0000\u1024\u1027\u0003\u0106\u0083\u0000\u1025"+
		"\u1027\u0003\u0102\u0081\u0000\u1026\u1024\u0001\u0000\u0000\u0000\u1026"+
		"\u1025\u0001\u0000\u0000\u0000\u1027\u1028\u0001\u0000\u0000\u0000\u1028"+
		"\u102d\u0005\u0483\u0000\u0000\u1029\u102b\u0005\f\u0000\u0000\u102a\u1029"+
		"\u0001\u0000\u0000\u0000\u102a\u102b\u0001\u0000\u0000\u0000\u102b\u102c"+
		"\u0001\u0000\u0000\u0000\u102c\u102e\u0003\u0250\u0128\u0000\u102d\u102a"+
		"\u0001\u0000\u0000\u0000\u102d\u102e\u0001\u0000\u0000\u0000\u102e\u1030"+
		"\u0001\u0000\u0000\u0000\u102f\u1021\u0001\u0000\u0000\u0000\u102f\u1022"+
		"\u0001\u0000\u0000\u0000\u102f\u1023\u0001\u0000\u0000\u0000\u1030\u010d"+
		"\u0001\u0000\u0000\u0000\u1031\u1032\u0005\u0116\u0000\u0000\u1032\u1033"+
		"\u0005\u0482\u0000\u0000\u1033\u1034\u0005\u0491\u0000\u0000\u1034\u1035"+
		"\u0005\u0484\u0000\u0000\u1035\u1036\u0005\u0491\u0000\u0000\u1036\u1037"+
		"\u0005\u016d\u0000\u0000\u1037\u1038\u0005\u0482\u0000\u0000\u1038\u1039"+
		"\u0003\u0110\u0088\u0000\u1039\u103a\u0005\u0483\u0000\u0000\u103a\u103f"+
		"\u0005\u0483\u0000\u0000\u103b\u103d\u0005\f\u0000\u0000\u103c\u103b\u0001"+
		"\u0000\u0000\u0000\u103c\u103d\u0001\u0000\u0000\u0000\u103d\u103e\u0001"+
		"\u0000\u0000\u0000\u103e\u1040\u0003\u0250\u0128\u0000\u103f\u103c\u0001"+
		"\u0000\u0000\u0000\u103f\u1040\u0001\u0000\u0000\u0000\u1040\u010f\u0001"+
		"\u0000\u0000\u0000\u1041\u1046\u0003\u0112\u0089\u0000\u1042\u1043\u0005"+
		"\u0484\u0000\u0000\u1043\u1045\u0003\u0112\u0089\u0000\u1044\u1042\u0001"+
		"\u0000\u0000\u0000\u1045\u1048\u0001\u0000\u0000\u0000\u1046\u1044\u0001"+
		"\u0000\u0000\u0000\u1046\u1047\u0001\u0000\u0000\u0000\u1047\u0111\u0001"+
		"\u0000\u0000\u0000\u1048\u1046\u0001\u0000\u0000\u0000\u1049\u105a\u0003"+
		"\u0232\u0119\u0000\u104a\u104b\u0005A\u0000\u0000\u104b\u105b\u0005\u011c"+
		"\u0000\u0000\u104c\u1058\u0003\u0264\u0132\u0000\u104d\u104e\u0005\u011d"+
		"\u0000\u0000\u104e\u1050\u0005\u0491\u0000\u0000\u104f\u1051\u0003\u0114"+
		"\u008a\u0000\u1050\u104f\u0001\u0000\u0000\u0000\u1050\u1051\u0001\u0000"+
		"\u0000\u0000\u1051\u1053\u0001\u0000\u0000\u0000\u1052\u1054\u0003\u0116"+
		"\u008b\u0000\u1053\u1052\u0001\u0000\u0000\u0000\u1053\u1054\u0001\u0000"+
		"\u0000\u0000\u1054\u1059\u0001\u0000\u0000\u0000\u1055\u1056\u0005<\u0000"+
		"\u0000\u1056\u1057\u0005\u011d\u0000\u0000\u1057\u1059\u0005\u0491\u0000"+
		"\u0000\u1058\u104d\u0001\u0000\u0000\u0000\u1058\u1055\u0001\u0000\u0000"+
		"\u0000\u1059\u105b\u0001\u0000\u0000\u0000\u105a\u104a\u0001\u0000\u0000"+
		"\u0000\u105a\u104c\u0001\u0000\u0000\u0000\u105b\u1067\u0001\u0000\u0000"+
		"\u0000\u105c\u105e\u0005\u011b\u0000\u0000\u105d\u105f\u0005\u011d\u0000"+
		"\u0000\u105e\u105d\u0001\u0000\u0000\u0000\u105e\u105f\u0001\u0000\u0000"+
		"\u0000\u105f\u1060\u0001\u0000\u0000\u0000\u1060\u1061\u0005\u0491\u0000"+
		"\u0000\u1061\u1062\u0005\u016d\u0000\u0000\u1062\u1063\u0005\u0482\u0000"+
		"\u0000\u1063\u1064\u0003\u0110\u0088\u0000\u1064\u1065\u0005\u0483\u0000"+
		"\u0000\u1065\u1067\u0001\u0000\u0000\u0000\u1066\u1049\u0001\u0000\u0000"+
		"\u0000\u1066\u105c\u0001\u0000\u0000\u0000\u1067\u0113\u0001\u0000\u0000"+
		"\u0000\u1068\u106d\u0005t\u0000\u0000\u1069\u106d\u0005\u019b\u0000\u0000"+
		"\u106a\u106b\u0005+\u0000\u0000\u106b\u106d\u0003\u0282\u0141\u0000\u106c"+
		"\u1068\u0001\u0000\u0000\u0000\u106c\u1069\u0001\u0000\u0000\u0000\u106c"+
		"\u106a\u0001\u0000\u0000\u0000\u106d\u106e\u0001\u0000\u0000\u0000\u106e"+
		"\u106f\u0005v\u0000\u0000\u106f\u1070\u00058\u0000\u0000\u1070\u0115\u0001"+
		"\u0000\u0000\u0000\u1071\u1076\u0005t\u0000\u0000\u1072\u1076\u0005\u019b"+
		"\u0000\u0000\u1073\u1074\u0005+\u0000\u0000\u1074\u1076\u0003\u0282\u0141"+
		"\u0000\u1075\u1071\u0001\u0000\u0000\u0000\u1075\u1072\u0001\u0000\u0000"+
		"\u0000\u1075\u1073\u0001\u0000\u0000\u0000\u1076\u1077\u0001\u0000\u0000"+
		"\u0000\u1077\u1078\u0005v\u0000\u0000\u1078\u1079\u0005\u019b\u0000\u0000"+
		"\u1079\u0117\u0001\u0000\u0000\u0000\u107a\u1083\u00077\u0000\u0000\u107b"+
		"\u1083\u0005K\u0000\u0000\u107c\u1083\u0005\u00ab\u0000\u0000\u107d\u1083"+
		"\u0005\u00a6\u0000\u0000\u107e\u1083\u0005\u00a4\u0000\u0000\u107f\u1083"+
		"\u0005\u0274\u0000\u0000\u1080\u1083\u00078\u0000\u0000\u1081\u1083\u0005"+
		"\u00a5\u0000\u0000\u1082\u107a\u0001\u0000\u0000\u0000\u1082\u107b\u0001"+
		"\u0000\u0000\u0000\u1082\u107c\u0001\u0000\u0000\u0000\u1082\u107d\u0001"+
		"\u0000\u0000\u0000\u1082\u107e\u0001\u0000\u0000\u0000\u1082\u107f\u0001"+
		"\u0000\u0000\u0000\u1082\u1080\u0001\u0000\u0000\u0000\u1082\u1081\u0001"+
		"\u0000\u0000\u0000\u1083\u0119\u0001\u0000\u0000\u0000\u1084\u1087\u0005"+
		"\u0472\u0000\u0000\u1085\u1087\u0003\u011c\u008e\u0000\u1086\u1084\u0001"+
		"\u0000\u0000\u0000\u1086\u1085\u0001\u0000\u0000\u0000\u1087\u108c\u0001"+
		"\u0000\u0000\u0000\u1088\u1089\u0005\u0484\u0000\u0000\u1089\u108b\u0003"+
		"\u011c\u008e\u0000\u108a\u1088\u0001\u0000\u0000\u0000\u108b\u108e\u0001"+
		"\u0000\u0000\u0000\u108c\u108a\u0001\u0000\u0000\u0000\u108c\u108d\u0001"+
		"\u0000\u0000\u0000\u108d\u011b\u0001\u0000\u0000\u0000\u108e\u108c\u0001"+
		"\u0000\u0000\u0000\u108f\u1090\u0003\u022c\u0116\u0000\u1090\u1091\u0005"+
		"\u0481\u0000\u0000\u1091\u1092\u0005\u0472\u0000\u0000\u1092\u10ad\u0001"+
		"\u0000\u0000\u0000\u1093\u1098\u0003\u0232\u0119\u0000\u1094\u1096\u0005"+
		"\f\u0000\u0000\u1095\u1094\u0001\u0000\u0000\u0000\u1095\u1096\u0001\u0000"+
		"\u0000\u0000\u1096\u1097\u0001\u0000\u0000\u0000\u1097\u1099\u0003\u0250"+
		"\u0128\u0000\u1098\u1095\u0001\u0000\u0000\u0000\u1098\u1099\u0001\u0000"+
		"\u0000\u0000\u1099\u10ad\u0001\u0000\u0000\u0000\u109a\u109f\u0003\u0292"+
		"\u0149\u0000\u109b\u109d\u0005\f\u0000\u0000\u109c\u109b\u0001\u0000\u0000"+
		"\u0000\u109c\u109d\u0001\u0000\u0000\u0000\u109d\u109e\u0001\u0000\u0000"+
		"\u0000\u109e\u10a0\u0003\u0250\u0128\u0000\u109f\u109c\u0001\u0000\u0000"+
		"\u0000\u109f\u10a0\u0001\u0000\u0000\u0000\u10a0\u10ad\u0001\u0000\u0000"+
		"\u0000\u10a1\u10a2\u0005\u049c\u0000\u0000\u10a2\u10a4\u0005\u0469\u0000"+
		"\u0000\u10a3\u10a1\u0001\u0000\u0000\u0000\u10a3\u10a4\u0001\u0000\u0000"+
		"\u0000\u10a4\u10a5\u0001\u0000\u0000\u0000\u10a5\u10aa\u0003\u02ba\u015d"+
		"\u0000\u10a6\u10a8\u0005\f\u0000\u0000\u10a7\u10a6\u0001\u0000\u0000\u0000"+
		"\u10a7\u10a8\u0001\u0000\u0000\u0000\u10a8\u10a9\u0001\u0000\u0000\u0000"+
		"\u10a9\u10ab\u0003\u0250\u0128\u0000\u10aa\u10a7\u0001\u0000\u0000\u0000"+
		"\u10aa\u10ab\u0001\u0000\u0000\u0000\u10ab\u10ad\u0001\u0000\u0000\u0000"+
		"\u10ac\u108f\u0001\u0000\u0000\u0000\u10ac\u1093\u0001\u0000\u0000\u0000"+
		"\u10ac\u109a\u0001\u0000\u0000\u0000\u10ac\u10a3\u0001\u0000\u0000\u0000"+
		"\u10ad\u011d\u0001\u0000\u0000\u0000\u10ae\u10af\u0005W\u0000\u0000\u10af"+
		"\u10b4\u0003\u00dcn\u0000\u10b0\u10b1\u0005\u0484\u0000\u0000\u10b1\u10b3"+
		"\u0003\u00dcn\u0000\u10b2\u10b0\u0001\u0000\u0000\u0000\u10b3\u10b6\u0001"+
		"\u0000\u0000\u0000\u10b4\u10b2\u0001\u0000\u0000\u0000\u10b4\u10b5\u0001"+
		"\u0000\u0000\u0000\u10b5\u10d3\u0001\u0000\u0000\u0000\u10b6\u10b4\u0001"+
		"\u0000\u0000\u0000\u10b7\u10b8\u0005W\u0000\u0000\u10b8\u10b9\u0005\u0190"+
		"\u0000\u0000\u10b9\u10d3\u0005\u0491\u0000\u0000\u10ba\u10bb\u0005W\u0000"+
		"\u0000\u10bb\u10bc\u0005\u007f\u0000\u0000\u10bc\u10c0\u0005\u0491\u0000"+
		"\u0000\u10bd\u10be\u0005\u001a\u0000\u0000\u10be\u10bf\u0005\u009a\u0000"+
		"\u0000\u10bf\u10c1\u0003\u023e\u011f\u0000\u10c0\u10bd\u0001\u0000\u0000"+
		"\u0000\u10c0\u10c1\u0001\u0000\u0000\u0000\u10c1\u10c8\u0001\u0000\u0000"+
		"\u0000\u10c2\u10c4\u0007,\u0000\u0000\u10c3\u10c5\u0003\u0120\u0090\u0000"+
		"\u10c4\u10c3\u0001\u0000\u0000\u0000\u10c5\u10c6\u0001\u0000\u0000\u0000"+
		"\u10c6\u10c4\u0001\u0000\u0000\u0000\u10c6\u10c7\u0001\u0000\u0000\u0000"+
		"\u10c7\u10c9\u0001\u0000\u0000\u0000\u10c8\u10c2\u0001\u0000\u0000\u0000"+
		"\u10c8\u10c9\u0001\u0000\u0000\u0000\u10c9\u10d0\u0001\u0000\u0000\u0000"+
		"\u10ca\u10cc\u0005e\u0000\u0000\u10cb\u10cd\u0003\u0122\u0091\u0000\u10cc"+
		"\u10cb\u0001\u0000\u0000\u0000\u10cd\u10ce\u0001\u0000\u0000\u0000\u10ce"+
		"\u10cc\u0001\u0000\u0000\u0000\u10ce\u10cf\u0001\u0000\u0000\u0000\u10cf"+
		"\u10d1\u0001\u0000\u0000\u0000\u10d0\u10ca\u0001\u0000\u0000\u0000\u10d0"+
		"\u10d1\u0001\u0000\u0000\u0000\u10d1\u10d3\u0001\u0000\u0000\u0000\u10d2"+
		"\u10ae\u0001\u0000\u0000\u0000\u10d2\u10b7\u0001\u0000\u0000\u0000\u10d2"+
		"\u10ba\u0001\u0000\u0000\u0000\u10d3\u011f\u0001\u0000\u0000\u0000\u10d4"+
		"\u10d5\u0005\u00ad\u0000\u0000\u10d5\u10d6\u0005\u0014\u0000\u0000\u10d6"+
		"\u10e1\u0005\u0491\u0000\u0000\u10d7\u10d9\u0005z\u0000\u0000\u10d8\u10d7"+
		"\u0001\u0000\u0000\u0000\u10d8\u10d9\u0001\u0000\u0000\u0000\u10d9\u10da"+
		"\u0001\u0000\u0000\u0000\u10da\u10db\u00059\u0000\u0000\u10db\u10dc\u0005"+
		"\u0014\u0000\u0000\u10dc\u10e1\u0005\u0491\u0000\u0000\u10dd\u10de\u0005"+
		":\u0000\u0000\u10de\u10df\u0005\u0014\u0000\u0000\u10df\u10e1\u0005\u0491"+
		"\u0000\u0000\u10e0\u10d4\u0001\u0000\u0000\u0000\u10e0\u10d8\u0001\u0000"+
		"\u0000\u0000\u10e0\u10dd\u0001\u0000\u0000\u0000\u10e1\u0121\u0001\u0000"+
		"\u0000\u0000\u10e2\u10e3\u0005\u00a9\u0000\u0000\u10e3\u10e4\u0005\u0014"+
		"\u0000\u0000\u10e4\u10e9\u0005\u0491\u0000\u0000\u10e5\u10e6\u0005\u00ad"+
		"\u0000\u0000\u10e6\u10e7\u0005\u0014\u0000\u0000\u10e7\u10e9\u0005\u0491"+
		"\u0000\u0000\u10e8\u10e2\u0001\u0000\u0000\u0000\u10e8\u10e5\u0001\u0000"+
		"\u0000\u0000\u10e9\u0123\u0001\u0000\u0000\u0000\u10ea\u10eb\u0005D\u0000"+
		"\u0000\u10eb\u10ed\u0003\u00f4z\u0000\u10ec\u10ea\u0001\u0000\u0000\u0000"+
		"\u10ec\u10ed\u0001\u0000\u0000\u0000\u10ed\u10f0\u0001\u0000\u0000\u0000"+
		"\u10ee\u10ef\u0005\u00be\u0000\u0000\u10ef\u10f1\u0003\u02ba\u015d\u0000"+
		"\u10f0\u10ee\u0001\u0000\u0000\u0000\u10f0\u10f1\u0001\u0000\u0000\u0000"+
		"\u10f1\u0125\u0001\u0000\u0000\u0000\u10f2\u10f3\u0005I\u0000\u0000\u10f3"+
		"\u10f4\u0005\u0014\u0000\u0000\u10f4\u10f9\u0003\u012c\u0096\u0000\u10f5"+
		"\u10f6\u0005\u0484\u0000\u0000\u10f6\u10f8\u0003\u012c\u0096\u0000\u10f7"+
		"\u10f5\u0001\u0000\u0000\u0000\u10f8\u10fb\u0001\u0000\u0000\u0000\u10f9"+
		"\u10f7\u0001\u0000\u0000\u0000\u10f9\u10fa\u0001\u0000\u0000\u0000\u10fa"+
		"\u10fe\u0001\u0000\u0000\u0000\u10fb\u10f9\u0001\u0000\u0000\u0000\u10fc"+
		"\u10fd\u0005\u00c0\u0000\u0000\u10fd\u10ff\u0005\u0258\u0000\u0000\u10fe"+
		"\u10fc\u0001\u0000\u0000\u0000\u10fe\u10ff\u0001\u0000\u0000\u0000\u10ff"+
		"\u0127\u0001\u0000\u0000\u0000\u1100\u1101\u0005J\u0000\u0000\u1101\u1102"+
		"\u0003\u02ba\u015d\u0000\u1102\u0129\u0001\u0000\u0000\u0000\u1103\u1104"+
		"\u0005\u02a8\u0000\u0000\u1104\u1105\u0003\u02a4\u0152\u0000\u1105\u1106"+
		"\u0005\f\u0000\u0000\u1106\u1107\u0005\u0482\u0000\u0000\u1107\u1108\u0003"+
		"\u02a2\u0151\u0000\u1108\u1112\u0005\u0483\u0000\u0000\u1109\u110a\u0005"+
		"\u0484\u0000\u0000\u110a\u110b\u0003\u02a4\u0152\u0000\u110b\u110c\u0005"+
		"\f\u0000\u0000\u110c\u110d\u0005\u0482\u0000\u0000\u110d\u110e\u0003\u02a2"+
		"\u0151\u0000\u110e\u110f\u0005\u0483\u0000\u0000\u110f\u1111\u0001\u0000"+
		"\u0000\u0000\u1110\u1109\u0001\u0000\u0000\u0000\u1111\u1114\u0001\u0000"+
		"\u0000\u0000\u1112\u1110\u0001\u0000\u0000\u0000\u1112\u1113\u0001\u0000"+
		"\u0000\u0000\u1113\u012b\u0001\u0000\u0000\u0000\u1114\u1112\u0001\u0000"+
		"\u0000\u0000\u1115\u1117\u0003\u02ba\u015d\u0000\u1116\u1118\u00073\u0000"+
		"\u0000\u1117\u1116\u0001\u0000\u0000\u0000\u1117\u1118\u0001\u0000\u0000"+
		"\u0000\u1118\u012d\u0001\u0000\u0000\u0000\u1119\u1124\u0005c\u0000\u0000"+
		"\u111a\u111b\u0003\u0130\u0098\u0000\u111b\u111c\u0005\u0484\u0000\u0000"+
		"\u111c\u111e\u0001\u0000\u0000\u0000\u111d\u111a\u0001\u0000\u0000\u0000"+
		"\u111d\u111e\u0001\u0000\u0000\u0000\u111e\u111f\u0001\u0000\u0000\u0000"+
		"\u111f\u1125\u0003\u0130\u0098\u0000\u1120\u1121\u0003\u0130\u0098\u0000"+
		"\u1121\u1122\u0005\u0215\u0000\u0000\u1122\u1123\u0003\u0130\u0098\u0000"+
		"\u1123\u1125\u0001\u0000\u0000\u0000\u1124\u111d\u0001\u0000\u0000\u0000"+
		"\u1124\u1120\u0001\u0000\u0000\u0000\u1125\u012f\u0001\u0000\u0000\u0000"+
		"\u1126\u112a\u0003\u0256\u012b\u0000\u1127\u112a\u0003\u023c\u011e\u0000"+
		"\u1128\u112a\u0003\u0252\u0129\u0000\u1129\u1126\u0001\u0000\u0000\u0000"+
		"\u1129\u1127\u0001\u0000\u0000\u0000\u1129\u1128\u0001\u0000\u0000\u0000"+
		"\u112a\u0131\u0001\u0000\u0000\u0000\u112b\u112c\u0005\u0278\u0000\u0000"+
		"\u112c\u1135\u0005\u0290\u0000\u0000\u112d\u1132\u0003\u0148\u00a4\u0000"+
		"\u112e\u112f\u0005\u0484\u0000\u0000\u112f\u1131\u0003\u0148\u00a4\u0000"+
		"\u1130\u112e\u0001\u0000\u0000\u0000\u1131\u1134\u0001\u0000\u0000\u0000"+
		"\u1132\u1130\u0001\u0000\u0000\u0000\u1132\u1133\u0001\u0000\u0000\u0000"+
		"\u1133\u1136\u0001\u0000\u0000\u0000\u1134\u1132\u0001\u0000\u0000\u0000"+
		"\u1135\u112d\u0001\u0000\u0000\u0000\u1135\u1136\u0001\u0000\u0000\u0000"+
		"\u1136\u0133\u0001\u0000\u0000\u0000\u1137\u1139\u0005\u0158\u0000\u0000"+
		"\u1138\u113a\u0005\u02aa\u0000\u0000\u1139\u1138\u0001\u0000\u0000\u0000"+
		"\u1139\u113a\u0001\u0000\u0000\u0000\u113a\u0135\u0001\u0000\u0000\u0000"+
		"\u113b\u113d\u0005\u0171\u0000\u0000\u113c\u113e\u0005\u02aa\u0000\u0000"+
		"\u113d\u113c\u0001\u0000\u0000\u0000\u113d\u113e\u0001\u0000\u0000\u0000"+
		"\u113e\u1144\u0001\u0000\u0000\u0000\u113f\u1141\u0005\n\u0000\u0000\u1140"+
		"\u1142\u0005\u020a\u0000\u0000\u1141\u1140\u0001\u0000\u0000\u0000\u1141"+
		"\u1142\u0001\u0000\u0000\u0000\u1142\u1143\u0001\u0000\u0000\u0000\u1143"+
		"\u1145\u0005\u0161\u0000\u0000\u1144\u113f\u0001\u0000\u0000\u0000\u1144"+
		"\u1145\u0001\u0000\u0000\u0000\u1145\u114a\u0001\u0000\u0000\u0000\u1146"+
		"\u1148\u0005\u020a\u0000\u0000\u1147\u1146\u0001\u0000\u0000\u0000\u1147"+
		"\u1148\u0001\u0000\u0000\u0000\u1148\u1149\u0001\u0000\u0000\u0000\u1149"+
		"\u114b\u0005\u008b\u0000\u0000\u114a\u1147\u0001\u0000\u0000\u0000\u114a"+
		"\u114b\u0001\u0000\u0000\u0000\u114b\u0137\u0001\u0000\u0000\u0000\u114c"+
		"\u114e\u0005\u0257\u0000\u0000\u114d\u114f\u0005\u02aa\u0000\u0000\u114e"+
		"\u114d\u0001\u0000\u0000\u0000\u114e\u114f\u0001\u0000\u0000\u0000\u114f"+
		"\u1155\u0001\u0000\u0000\u0000\u1150\u1152\u0005\n\u0000\u0000\u1151\u1153"+
		"\u0005\u020a\u0000\u0000\u1152\u1151\u0001\u0000\u0000\u0000\u1152\u1153"+
		"\u0001\u0000\u0000\u0000\u1153\u1154\u0001\u0000\u0000\u0000\u1154\u1156"+
		"\u0005\u0161\u0000\u0000\u1155\u1150\u0001\u0000\u0000\u0000\u1155\u1156"+
		"\u0001\u0000\u0000\u0000\u1156\u115b\u0001\u0000\u0000\u0000\u1157\u1159"+
		"\u0005\u020a\u0000\u0000\u1158\u1157\u0001\u0000\u0000\u0000\u1158\u1159"+
		"\u0001\u0000\u0000\u0000\u1159\u115a\u0001\u0000\u0000\u0000\u115a\u115c"+
		"\u0005\u008b\u0000\u0000\u115b\u1158\u0001\u0000\u0000\u0000\u115b\u115c"+
		"\u0001\u0000\u0000\u0000\u115c\u0139\u0001\u0000\u0000\u0000\u115d\u115e"+
		"\u0005\u025e\u0000\u0000\u115e\u115f\u0003\u0250\u0128\u0000\u115f\u013b"+
		"\u0001\u0000\u0000\u0000\u1160\u1162\u0005\u0257\u0000\u0000\u1161\u1163"+
		"\u0005\u02aa\u0000\u0000\u1162\u1161\u0001\u0000\u0000\u0000\u1162\u1163"+
		"\u0001\u0000\u0000\u0000\u1163\u1164\u0001\u0000\u0000\u0000\u1164\u1166"+
		"\u0005\u00af\u0000\u0000\u1165\u1167\u0005\u025e\u0000\u0000\u1166\u1165"+
		"\u0001\u0000\u0000\u0000\u1166\u1167\u0001\u0000\u0000\u0000\u1167\u1168"+
		"\u0001\u0000\u0000\u0000\u1168\u1169\u0003\u0250\u0128\u0000\u1169\u013d"+
		"\u0001\u0000\u0000\u0000\u116a\u116b\u0005\u008b\u0000\u0000\u116b\u116c"+
		"\u0005\u025e\u0000\u0000\u116c\u116d\u0003\u0250\u0128\u0000\u116d\u013f"+
		"\u0001\u0000\u0000\u0000\u116e\u116f\u0005g\u0000\u0000\u116f\u1170\u0007"+
		"9\u0000\u0000\u1170\u1175\u0003\u014a\u00a5\u0000\u1171\u1172\u0005\u0484"+
		"\u0000\u0000\u1172\u1174\u0003\u014a\u00a5\u0000\u1173\u1171\u0001\u0000"+
		"\u0000\u0000\u1174\u1177\u0001\u0000\u0000\u0000\u1175\u1173\u0001\u0000"+
		"\u0000\u0000\u1175\u1176\u0001\u0000\u0000\u0000\u1176\u1179\u0001\u0000"+
		"\u0000\u0000\u1177\u1175\u0001\u0000\u0000\u0000\u1178\u117a\u0003\u028e"+
		"\u0147\u0000\u1179\u1178\u0001\u0000\u0000\u0000\u1179\u117a\u0001\u0000"+
		"\u0000\u0000\u117a\u0141\u0001\u0000\u0000\u0000\u117b\u117c\u0005\u00b6"+
		"\u0000\u0000\u117c\u117d\u0005\u02ed\u0000\u0000\u117d\u0143\u0001\u0000"+
		"\u0000\u0000\u117e\u117f\u0005\u009a\u0000\u0000\u117f\u1180\u0005\u0154"+
		"\u0000\u0000\u1180\u1181\u0005\u0479\u0000\u0000\u1181\u1182\u0007\u001b"+
		"\u0000\u0000\u1182\u0145\u0001\u0000\u0000\u0000\u1183\u1185\u0005\u009a"+
		"\u0000\u0000\u1184\u1186\u0007:\u0000\u0000\u1185\u1184\u0001\u0000\u0000"+
		"\u0000\u1185\u1186\u0001\u0000\u0000\u0000\u1186\u1187\u0001\u0000\u0000"+
		"\u0000\u1187\u1188\u0005\u0290\u0000\u0000\u1188\u118d\u0003\u014e\u00a7"+
		"\u0000\u1189\u118a\u0005\u0484\u0000\u0000\u118a\u118c\u0003\u014e\u00a7"+
		"\u0000\u118b\u1189\u0001\u0000\u0000\u0000\u118c\u118f\u0001\u0000\u0000"+
		"\u0000\u118d\u118b\u0001\u0000\u0000\u0000\u118d\u118e\u0001\u0000\u0000"+
		"\u0000\u118e\u0147\u0001\u0000\u0000\u0000\u118f\u118d\u0001\u0000\u0000"+
		"\u0000\u1190\u1191\u0005\u00c0\u0000\u0000\u1191\u1192\u0005\u0179\u0000"+
		"\u0000\u1192\u1198\u0005\u026b\u0000\u0000\u1193\u1194\u0005\u0087\u0000"+
		"\u0000\u1194\u1198\u0005\u00c1\u0000\u0000\u1195\u1196\u0005\u0087\u0000"+
		"\u0000\u1196\u1198\u0005\u021b\u0000\u0000\u1197\u1190\u0001\u0000\u0000"+
		"\u0000\u1197\u1193\u0001\u0000\u0000\u0000\u1197\u1195\u0001\u0000\u0000"+
		"\u0000\u1198\u0149\u0001\u0000\u0000\u0000\u1199\u119e\u0003\u022e\u0117"+
		"\u0000\u119a\u119c\u0005\f\u0000\u0000\u119b\u119a\u0001\u0000\u0000\u0000"+
		"\u119b\u119c\u0001\u0000\u0000\u0000\u119c\u119d\u0001\u0000\u0000\u0000"+
		"\u119d\u119f\u0003\u0250\u0128\u0000\u119e\u119b\u0001\u0000\u0000\u0000"+
		"\u119e\u119f\u0001\u0000\u0000\u0000\u119f\u11a0\u0001\u0000\u0000\u0000"+
		"\u11a0\u11a1\u0003\u014c\u00a6\u0000\u11a1\u014b\u0001\u0000\u0000\u0000"+
		"\u11a2\u11a4\u0005\u0087\u0000\u0000\u11a3\u11a5\u0005\u01da\u0000\u0000"+
		"\u11a4\u11a3\u0001\u0000\u0000\u0000\u11a4\u11a5\u0001\u0000\u0000\u0000"+
		"\u11a5\u11ab\u0001\u0000\u0000\u0000\u11a6\u11a8\u0005j\u0000\u0000\u11a7"+
		"\u11a6\u0001\u0000\u0000\u0000\u11a7\u11a8\u0001\u0000\u0000\u0000\u11a8"+
		"\u11a9\u0001\u0000\u0000\u0000\u11a9\u11ab\u0005\u00c1\u0000\u0000\u11aa"+
		"\u11a2\u0001\u0000\u0000\u0000\u11aa\u11a7\u0001\u0000\u0000\u0000\u11ab"+
		"\u014d\u0001\u0000\u0000\u0000\u11ac\u11ad\u0005\u01d0\u0000\u0000\u11ad"+
		"\u11ae\u0005\u01d8\u0000\u0000\u11ae\u11b4\u0003\u0150\u00a8\u0000\u11af"+
		"\u11b0\u0005\u0087\u0000\u0000\u11b0\u11b4\u0005\u00c1\u0000\u0000\u11b1"+
		"\u11b2\u0005\u0087\u0000\u0000\u11b2\u11b4\u0005\u021b\u0000\u0000\u11b3"+
		"\u11ac\u0001\u0000\u0000\u0000\u11b3\u11af\u0001\u0000\u0000\u0000\u11b3"+
		"\u11b1\u0001\u0000\u0000\u0000\u11b4\u014f\u0001\u0000\u0000\u0000\u11b5"+
		"\u11b6\u0005\u0326\u0000\u0000\u11b6\u11bd\u0005\u0087\u0000\u0000\u11b7"+
		"\u11b8\u0005\u0087\u0000\u0000\u11b8\u11bd\u0005\u0327\u0000\u0000\u11b9"+
		"\u11ba\u0005\u0087\u0000\u0000\u11ba\u11bd\u0005\u0328\u0000\u0000\u11bb"+
		"\u11bd\u0005\u0329\u0000\u0000\u11bc\u11b5\u0001\u0000\u0000\u0000\u11bc"+
		"\u11b7\u0001\u0000\u0000\u0000\u11bc\u11b9\u0001\u0000\u0000\u0000\u11bc"+
		"\u11bb\u0001\u0000\u0000\u0000\u11bd\u0151\u0001\u0000\u0000\u0000\u11be"+
		"\u11bf\u0005\u0019\u0000\u0000\u11bf\u11c0\u0005\u01de\u0000\u0000\u11c0"+
		"\u11c1\u0005\u00af\u0000\u0000\u11c1\u11c6\u0003\u0164\u00b2\u0000\u11c2"+
		"\u11c3\u0005\u0484\u0000\u0000\u11c3\u11c5\u0003\u0164\u00b2\u0000\u11c4"+
		"\u11c2\u0001\u0000\u0000\u0000\u11c5\u11c8\u0001\u0000\u0000\u0000\u11c6"+
		"\u11c4\u0001\u0000\u0000\u0000\u11c6\u11c7\u0001\u0000\u0000\u0000\u11c7"+
		"\u11ca\u0001\u0000\u0000\u0000\u11c8\u11c6\u0001\u0000\u0000\u0000\u11c9"+
		"\u11cb\u0003\u016c\u00b6\u0000\u11ca\u11c9\u0001\u0000\u0000\u0000\u11ca"+
		"\u11cb\u0001\u0000\u0000\u0000\u11cb\u0153\u0001\u0000\u0000\u0000\u11cc"+
		"\u11cd\u0005\u0019\u0000\u0000\u11cd\u11ce\u0005\u024e\u0000\u0000\u11ce"+
		"\u11cf\u0005\u01ad\u0000\u0000\u11cf\u11d4\u0003\u016e\u00b7\u0000\u11d0"+
		"\u11d1\u0005\u0484\u0000\u0000\u11d1\u11d3\u0003\u016e\u00b7\u0000\u11d2"+
		"\u11d0\u0001\u0000\u0000\u0000\u11d3\u11d6\u0001\u0000\u0000\u0000\u11d4"+
		"\u11d2\u0001\u0000\u0000\u0000\u11d4\u11d5\u0001\u0000\u0000\u0000\u11d5"+
		"\u0155\u0001\u0000\u0000\u0000\u11d6\u11d4\u0001\u0000\u0000\u0000\u11d7"+
		"\u11d8\u0005\u0085\u0000\u0000\u11d8\u11d9\u0007;\u0000\u0000\u11d9\u11de"+
		"\u0005\u01dd\u0000\u0000\u11da\u11db\u0005\u00af\u0000\u0000\u11db\u11df"+
		"\u0005\u0491\u0000\u0000\u11dc\u11dd\u0005\u000f\u0000\u0000\u11dd\u11df"+
		"\u0005\u0491\u0000\u0000\u11de\u11da\u0001\u0000\u0000\u0000\u11de\u11dc"+
		"\u0001\u0000\u0000\u0000\u11df\u0157\u0001\u0000\u0000\u0000\u11e0\u11e1"+
		"\u0005\u024f\u0000\u0000\u11e1\u11e2\u0005\u01de\u0000\u0000\u11e2\u0159"+
		"\u0001\u0000\u0000\u0000\u11e3\u11e4\u0005\u024f\u0000\u0000\u11e4\u11e6"+
		"\u0005\u0268\u0000\u0000\u11e5\u11e7\u0005\u0006\u0000\u0000\u11e6\u11e5"+
		"\u0001\u0000\u0000\u0000\u11e6\u11e7\u0001\u0000\u0000\u0000\u11e7\u11e9"+
		"\u0001\u0000\u0000\u0000\u11e8\u11ea\u0003\u016c\u00b6\u0000\u11e9\u11e8"+
		"\u0001\u0000\u0000\u0000\u11e9\u11ea\u0001\u0000\u0000\u0000\u11ea\u015b"+
		"\u0001\u0000\u0000\u0000\u11eb\u11ec\u0005\u0278\u0000\u0000\u11ec\u11f5"+
		"\u0005\u0268\u0000\u0000\u11ed\u11f2\u0003\u0172\u00b9\u0000\u11ee\u11ef"+
		"\u0005\u0484\u0000\u0000\u11ef\u11f1\u0003\u0172\u00b9\u0000\u11f0\u11ee"+
		"\u0001\u0000\u0000\u0000\u11f1\u11f4\u0001\u0000\u0000\u0000\u11f2\u11f0"+
		"\u0001\u0000\u0000\u0000\u11f2\u11f3\u0001\u0000\u0000\u0000\u11f3\u11f6"+
		"\u0001\u0000\u0000\u0000\u11f4\u11f2\u0001\u0000\u0000\u0000\u11f5\u11ed"+
		"\u0001\u0000\u0000\u0000\u11f5\u11f6\u0001\u0000\u0000\u0000\u11f6\u11f9"+
		"\u0001\u0000\u0000\u0000\u11f7\u11f8\u0005\u029b\u0000\u0000\u11f8\u11fa"+
		"\u0003\u0174\u00ba\u0000\u11f9\u11f7\u0001\u0000\u0000\u0000\u11f9\u11fa"+
		"\u0001\u0000\u0000\u0000\u11fa\u11fe\u0001\u0000\u0000\u0000\u11fb\u11fd"+
		"\u0003\u0176\u00bb\u0000\u11fc\u11fb\u0001\u0000\u0000\u0000\u11fd\u1200"+
		"\u0001\u0000\u0000\u0000\u11fe\u11fc\u0001\u0000\u0000\u0000\u11fe\u11ff"+
		"\u0001\u0000\u0000\u0000\u11ff\u1202\u0001\u0000\u0000\u0000\u1200\u11fe"+
		"\u0001\u0000\u0000\u0000\u1201\u1203\u0003\u016c\u00b6\u0000\u1202\u1201"+
		"\u0001\u0000\u0000\u0000\u1202\u1203\u0001\u0000\u0000\u0000\u1203\u015d"+
		"\u0001\u0000\u0000\u0000\u1204\u1205\u0005\u027e\u0000\u0000\u1205\u120e"+
		"\u0005\u0268\u0000\u0000\u1206\u120b\u0003\u0172\u00b9\u0000\u1207\u1208"+
		"\u0005\u0484\u0000\u0000\u1208\u120a\u0003\u0172\u00b9\u0000\u1209\u1207"+
		"\u0001\u0000\u0000\u0000\u120a\u120d\u0001\u0000\u0000\u0000\u120b\u1209"+
		"\u0001\u0000\u0000\u0000\u120b\u120c\u0001\u0000\u0000\u0000\u120c\u120f"+
		"\u0001\u0000\u0000\u0000\u120d\u120b\u0001\u0000\u0000\u0000\u120e\u1206"+
		"\u0001\u0000\u0000\u0000\u120e\u120f\u0001\u0000\u0000\u0000\u120f\u015f"+
		"\u0001\u0000\u0000\u0000\u1210\u1211\u0005\u0278\u0000\u0000\u1211\u1212"+
		"\u0005\u01b9\u0000\u0000\u1212\u0161\u0001\u0000\u0000\u0000\u1213\u1214"+
		"\u0005\u027e\u0000\u0000\u1214\u1215\u0005\u01b9\u0000\u0000\u1215\u0163"+
		"\u0001\u0000\u0000\u0000\u1216\u1217\u0003\u0166\u00b3\u0000\u1217\u1218"+
		"\u0005\u0479\u0000\u0000\u1218\u1219\u0005\u0491\u0000\u0000\u1219\u1234"+
		"\u0001\u0000\u0000\u0000\u121a\u121b\u0003\u0168\u00b4\u0000\u121b\u121c"+
		"\u0005\u0479\u0000\u0000\u121c\u121d\u0003\u0256\u012b\u0000\u121d\u1234"+
		"\u0001\u0000\u0000\u0000\u121e\u121f\u0003\u016a\u00b5\u0000\u121f\u1220"+
		"\u0005\u0479\u0000\u0000\u1220\u1221\u0007\u001b\u0000\u0000\u1221\u1234"+
		"\u0001\u0000\u0000\u0000\u1222\u1223\u0005\u01e2\u0000\u0000\u1223\u1224"+
		"\u0005\u0479\u0000\u0000\u1224\u1234\u0005\u0494\u0000\u0000\u1225\u1226"+
		"\u0005\u01c1\u0000\u0000\u1226\u1227\u0005\u0479\u0000\u0000\u1227\u1230"+
		"\u0005\u0482\u0000\u0000\u1228\u122d\u0003\u0250\u0128\u0000\u1229\u122a"+
		"\u0005\u0484\u0000\u0000\u122a\u122c\u0003\u0250\u0128\u0000\u122b\u1229"+
		"\u0001\u0000\u0000\u0000\u122c\u122f\u0001\u0000\u0000\u0000\u122d\u122b"+
		"\u0001\u0000\u0000\u0000\u122d\u122e\u0001\u0000\u0000\u0000\u122e\u1231"+
		"\u0001\u0000\u0000\u0000\u122f\u122d\u0001\u0000\u0000\u0000\u1230\u1228"+
		"\u0001\u0000\u0000\u0000\u1230\u1231\u0001\u0000\u0000\u0000\u1231\u1232"+
		"\u0001\u0000\u0000\u0000\u1232\u1234\u0005\u0483\u0000\u0000\u1233\u1216"+
		"\u0001\u0000\u0000\u0000\u1233\u121a\u0001\u0000\u0000\u0000\u1233\u121e"+
		"\u0001\u0000\u0000\u0000\u1233\u1222\u0001\u0000\u0000\u0000\u1233\u1225"+
		"\u0001\u0000\u0000\u0000\u1234\u0165\u0001\u0000\u0000\u0000\u1235\u1236"+
		"\u0007<\u0000\u0000\u1236\u0167\u0001\u0000\u0000\u0000\u1237\u1238\u0007"+
		"=\u0000\u0000\u1238\u0169\u0001\u0000\u0000\u0000\u1239\u123a\u0007>\u0000"+
		"\u0000\u123a\u016b\u0001\u0000\u0000\u0000\u123b\u123c\u0005A\u0000\u0000"+
		"\u123c\u123d\u0005\u0163\u0000\u0000\u123d\u123e\u0005\u0491\u0000\u0000"+
		"\u123e\u016d\u0001\u0000\u0000\u0000\u123f\u1240\u0005\u0247\u0000\u0000"+
		"\u1240\u1241\u0005\u0479\u0000\u0000\u1241\u1242\u0005\u0482\u0000\u0000"+
		"\u1242\u1243\u0003\u0272\u0139\u0000\u1243\u1244\u0005\u0483\u0000\u0000"+
		"\u1244\u1271\u0001\u0000\u0000\u0000\u1245\u1246\u0005\u0249\u0000\u0000"+
		"\u1246\u1247\u0005\u0479\u0000\u0000\u1247\u1248\u0005\u0482\u0000\u0000"+
		"\u1248\u1249\u0003\u0272\u0139\u0000\u1249\u124a\u0005\u0483\u0000\u0000"+
		"\u124a\u1271\u0001\u0000\u0000\u0000\u124b\u124c\u0005\u0248\u0000\u0000"+
		"\u124c\u124d\u0005\u0479\u0000\u0000\u124d\u124e\u0005\u0482\u0000\u0000"+
		"\u124e\u124f\u0003\u0274\u013a\u0000\u124f\u1250\u0005\u0483\u0000\u0000"+
		"\u1250\u1271\u0001\u0000\u0000\u0000\u1251\u1252\u0005\u024a\u0000\u0000"+
		"\u1252\u1253\u0005\u0479\u0000\u0000\u1253\u1254\u0005\u0482\u0000\u0000"+
		"\u1254\u1255\u0003\u0274\u013a\u0000\u1255\u1256\u0005\u0483\u0000\u0000"+
		"\u1256\u1271\u0001\u0000\u0000\u0000\u1257\u1258\u0005\u024c\u0000\u0000"+
		"\u1258\u1259\u0005\u0479\u0000\u0000\u1259\u125a\u0005\u0482\u0000\u0000"+
		"\u125a\u125b\u0003\u027e\u013f\u0000\u125b\u125c\u0005\u0483\u0000\u0000"+
		"\u125c\u1271\u0001\u0000\u0000\u0000\u125d\u125e\u0005\u024d\u0000\u0000"+
		"\u125e\u125f\u0005\u0479\u0000\u0000\u125f\u1260\u0005\u0482\u0000\u0000"+
		"\u1260\u1261\u0003\u027e\u013f\u0000\u1261\u1262\u0005\u0483\u0000\u0000"+
		"\u1262\u1271\u0001\u0000\u0000\u0000\u1263\u1264\u0005\u024b\u0000\u0000"+
		"\u1264\u1265\u0005\u0479\u0000\u0000\u1265\u1266\u0005\u0482\u0000\u0000"+
		"\u1266\u126b\u0003\u0170\u00b8\u0000\u1267\u1268\u0005\u0484\u0000\u0000"+
		"\u1268\u126a\u0003\u0170\u00b8\u0000\u1269\u1267\u0001\u0000\u0000\u0000"+
		"\u126a\u126d\u0001\u0000\u0000\u0000\u126b\u1269\u0001\u0000\u0000\u0000"+
		"\u126b\u126c\u0001\u0000\u0000\u0000\u126c\u126e\u0001\u0000\u0000\u0000"+
		"\u126d\u126b\u0001\u0000\u0000\u0000\u126e\u126f\u0005\u0483\u0000\u0000"+
		"\u126f\u1271\u0001\u0000\u0000\u0000\u1270\u123f\u0001\u0000\u0000\u0000"+
		"\u1270\u1245\u0001\u0000\u0000\u0000\u1270\u124b\u0001\u0000\u0000\u0000"+
		"\u1270\u1251\u0001\u0000\u0000\u0000\u1270\u1257\u0001\u0000\u0000\u0000"+
		"\u1270\u125d\u0001\u0000\u0000\u0000\u1270\u1263\u0001\u0000\u0000\u0000"+
		"\u1271\u016f\u0001\u0000\u0000\u0000\u1272\u1273\u0005\u0482\u0000\u0000"+
		"\u1273\u1274\u0003\u022e\u0117\u0000\u1274\u1275\u0005\u0484\u0000\u0000"+
		"\u1275\u1276\u0003\u022e\u0117\u0000\u1276\u1277\u0005\u0483\u0000\u0000"+
		"\u1277\u0171\u0001\u0000\u0000\u0000\u1278\u1279\u0007?\u0000\u0000\u1279"+
		"\u0173\u0001\u0000\u0000\u0000\u127a\u127b\u0007@\u0000\u0000\u127b\u127c"+
		"\u0005\u0479\u0000\u0000\u127c\u128d\u0003\u0178\u00bc\u0000\u127d\u127e"+
		"\u0005\u01e4\u0000\u0000\u127e\u127f\u0005\u0479\u0000\u0000\u127f\u1280"+
		"\u0005\u0491\u0000\u0000\u1280\u1281\u0005\u0484\u0000\u0000\u1281\u1282"+
		"\u0005\u01e5\u0000\u0000\u1282\u1283\u0005\u0479\u0000\u0000\u1283\u128d"+
		"\u0003\u0256\u012b\u0000\u1284\u1285\u0005\u0241\u0000\u0000\u1285\u1286"+
		"\u0005\u0479\u0000\u0000\u1286\u1287\u0005\u0491\u0000\u0000\u1287\u1288"+
		"\u0005\u0484\u0000\u0000\u1288\u1289\u0005\u0242\u0000\u0000\u1289\u128a"+
		"\u0005\u0479\u0000\u0000\u128a\u128d\u0003\u0256\u012b\u0000\u128b\u128d"+
		"\u0005\u0272\u0000\u0000\u128c\u127a\u0001\u0000\u0000\u0000\u128c\u127d"+
		"\u0001\u0000\u0000\u0000\u128c\u1284\u0001\u0000\u0000\u0000\u128c\u128b"+
		"\u0001\u0000\u0000\u0000\u128d\u0175\u0001\u0000\u0000\u0000\u128e\u128f"+
		"\u0005\u029d\u0000\u0000\u128f\u1290\u0005\u0479\u0000\u0000\u1290\u129b"+
		"\u0005\u0491\u0000\u0000\u1291\u1292\u0005\u0228\u0000\u0000\u1292\u1293"+
		"\u0005\u0479\u0000\u0000\u1293\u129b\u0005\u0491\u0000\u0000\u1294\u1295"+
		"\u0005\u0187\u0000\u0000\u1295\u1296\u0005\u0479\u0000\u0000\u1296\u129b"+
		"\u0005\u0491\u0000\u0000\u1297\u1298\u0005\u022c\u0000\u0000\u1298\u1299"+
		"\u0005\u0479\u0000\u0000\u1299\u129b\u0005\u0491\u0000\u0000\u129a\u128e"+
		"\u0001\u0000\u0000\u0000\u129a\u1291\u0001\u0000\u0000\u0000\u129a\u1294"+
		"\u0001\u0000\u0000\u0000\u129a\u1297\u0001\u0000\u0000\u0000\u129b\u0177"+
		"\u0001\u0000\u0000\u0000\u129c\u12a1\u0003\u0248\u0124\u0000\u129d\u129e"+
		"\u0005\u0484\u0000\u0000\u129e\u12a0\u0003\u0248\u0124\u0000\u129f\u129d"+
		"\u0001\u0000\u0000\u0000\u12a0\u12a3\u0001\u0000\u0000\u0000\u12a1\u129f"+
		"\u0001\u0000\u0000\u0000\u12a1\u12a2\u0001\u0000\u0000\u0000\u12a2\u12a6"+
		"\u0001\u0000\u0000\u0000\u12a3\u12a1\u0001\u0000\u0000\u0000\u12a4\u12a6"+
		"\u0005\u0491\u0000\u0000\u12a5\u129c\u0001\u0000\u0000\u0000\u12a5\u12a4"+
		"\u0001\u0000\u0000\u0000\u12a6\u0179\u0001\u0000\u0000\u0000\u12a7\u12a8"+
		"\u0005\u02af\u0000\u0000\u12a8\u12a9\u0007A\u0000\u0000\u12a9\u12ab\u0003"+
		"\u024a\u0125\u0000\u12aa\u12ac\u0007B\u0000\u0000\u12ab\u12aa\u0001\u0000"+
		"\u0000\u0000\u12ab\u12ac\u0001\u0000\u0000\u0000\u12ac\u017b\u0001\u0000"+
		"\u0000\u0000\u12ad\u12ae\u0005\u02af\u0000\u0000\u12ae\u12af\u0005\u0197"+
		"\u0000\u0000\u12af\u12b5\u0003\u024a\u0125\u0000\u12b0\u12b3\u0005\u0286"+
		"\u0000\u0000\u12b1\u12b2\u0005A\u0000\u0000\u12b2\u12b4\u0005\u01fe\u0000"+
		"\u0000\u12b3\u12b1\u0001\u0000\u0000\u0000\u12b3\u12b4\u0001\u0000\u0000"+
		"\u0000\u12b4\u12b6\u0001\u0000\u0000\u0000\u12b5\u12b0\u0001\u0000\u0000"+
		"\u0000\u12b5\u12b6\u0001\u0000\u0000\u0000\u12b6\u017d\u0001\u0000\u0000"+
		"\u0000\u12b7\u12b8\u0005\u02af\u0000\u0000\u12b8\u12b9\u0005\u0231\u0000"+
		"\u0000\u12b9\u12ba\u0003\u024a\u0125\u0000\u12ba\u017f\u0001\u0000\u0000"+
		"\u0000\u12bb\u12bc\u0005\u02af\u0000\u0000\u12bc\u12bd\u0005\u0171\u0000"+
		"\u0000\u12bd\u12c0\u0003\u024a\u0125\u0000\u12be\u12bf\u0005\u0219\u0000"+
		"\u0000\u12bf\u12c1\u0005\u022a\u0000\u0000\u12c0\u12be\u0001\u0000\u0000"+
		"\u0000\u12c0\u12c1\u0001\u0000\u0000\u0000\u12c1\u0181\u0001\u0000\u0000"+
		"\u0000\u12c2\u12c3\u0005\u02af\u0000\u0000\u12c3\u12c4\u0005\u0257\u0000"+
		"\u0000\u12c4\u12c5\u0003\u024a\u0125\u0000\u12c5\u0183\u0001\u0000\u0000"+
		"\u0000\u12c6\u12c7\u0005\u02af\u0000\u0000\u12c7\u12ca\u0005\u023c\u0000"+
		"\u0000\u12c8\u12c9\u0005!\u0000\u0000\u12c9\u12cb\u0003\u024a\u0125\u0000"+
		"\u12ca\u12c8\u0001\u0000\u0000\u0000\u12ca\u12cb\u0001\u0000\u0000\u0000"+
		"\u12cb\u0185\u0001\u0000\u0000\u0000\u12cc\u12cd\u0005\u0231\u0000\u0000"+
		"\u12cd\u12ce\u0003\u0250\u0128\u0000\u12ce\u12d1\u0005D\u0000\u0000\u12cf"+
		"\u12d2\u0005\u0491\u0000\u0000\u12d0\u12d2\u0005\u049c\u0000\u0000\u12d1"+
		"\u12cf\u0001\u0000\u0000\u0000\u12d1\u12d0\u0001\u0000\u0000\u0000\u12d2"+
		"\u0187\u0001\u0000\u0000\u0000\u12d3\u12d4\u0005\u02cc\u0000\u0000\u12d4"+
		"\u12d7\u0003\u0250\u0128\u0000\u12d5\u12d6\u0005\u00bb\u0000\u0000\u12d6"+
		"\u12d8\u0003\u0280\u0140\u0000\u12d7\u12d5\u0001\u0000\u0000\u0000\u12d7"+
		"\u12d8\u0001\u0000\u0000\u0000\u12d8\u0189\u0001\u0000\u0000\u0000\u12d9"+
		"\u12da\u0007C\u0000\u0000\u12da\u12db\u0005\u0231\u0000\u0000\u12db\u12dc"+
		"\u0003\u0250\u0128\u0000\u12dc\u018b\u0001\u0000\u0000\u0000\u12dd\u12e0"+
		"\u0003\u018e\u00c7\u0000\u12de\u12e0\u0003\u0004\u0002\u0000\u12df\u12dd"+
		"\u0001\u0000\u0000\u0000\u12df\u12de\u0001\u0000\u0000\u0000\u12e0\u018d"+
		"\u0001\u0000\u0000\u0000\u12e1\u12e2\u0003\u0250\u0128\u0000\u12e2\u12e3"+
		"\u0005\u048d\u0000\u0000\u12e3\u12e5\u0001\u0000\u0000\u0000\u12e4\u12e1"+
		"\u0001\u0000\u0000\u0000\u12e4\u12e5\u0001\u0000\u0000\u0000\u12e5\u12e6"+
		"\u0001\u0000\u0000\u0000\u12e6\u130d\u0005\u0158\u0000\u0000\u12e7\u12e8"+
		"\u0003\u01a2\u00d1\u0000\u12e8\u12e9\u0005\u0485\u0000\u0000\u12e9\u12eb"+
		"\u0001\u0000\u0000\u0000\u12ea\u12e7\u0001\u0000\u0000\u0000\u12eb\u12ee"+
		"\u0001\u0000\u0000\u0000\u12ec\u12ea\u0001\u0000\u0000\u0000\u12ec\u12ed"+
		"\u0001\u0000\u0000\u0000\u12ed\u12f4\u0001\u0000\u0000\u0000\u12ee\u12ec"+
		"\u0001\u0000\u0000\u0000\u12ef\u12f0\u0003\u01a4\u00d2\u0000\u12f0\u12f1"+
		"\u0005\u0485\u0000\u0000\u12f1\u12f3\u0001\u0000\u0000\u0000\u12f2\u12ef"+
		"\u0001\u0000\u0000\u0000\u12f3\u12f6\u0001\u0000\u0000\u0000\u12f4\u12f2"+
		"\u0001\u0000\u0000\u0000\u12f4\u12f5\u0001\u0000\u0000\u0000\u12f5\u12fc"+
		"\u0001\u0000\u0000\u0000\u12f6\u12f4\u0001\u0000\u0000\u0000\u12f7\u12f8"+
		"\u0003\u01a6\u00d3\u0000\u12f8\u12f9\u0005\u0485\u0000\u0000\u12f9\u12fb"+
		"\u0001\u0000\u0000\u0000\u12fa\u12f7\u0001\u0000\u0000\u0000\u12fb\u12fe"+
		"\u0001\u0000\u0000\u0000\u12fc\u12fa\u0001\u0000\u0000\u0000\u12fc\u12fd"+
		"\u0001\u0000\u0000\u0000\u12fd\u1304\u0001\u0000\u0000\u0000\u12fe\u12fc"+
		"\u0001\u0000\u0000\u0000\u12ff\u1300\u0003\u01a8\u00d4\u0000\u1300\u1301"+
		"\u0005\u0485\u0000\u0000\u1301\u1303\u0001\u0000\u0000\u0000\u1302\u12ff"+
		"\u0001\u0000\u0000\u0000\u1303\u1306\u0001\u0000\u0000\u0000\u1304\u1302"+
		"\u0001\u0000\u0000\u0000\u1304\u1305\u0001\u0000\u0000\u0000\u1305\u130a"+
		"\u0001\u0000\u0000\u0000\u1306\u1304\u0001\u0000\u0000\u0000\u1307\u1309"+
		"\u0003\u01ac\u00d6\u0000\u1308\u1307\u0001\u0000\u0000\u0000\u1309\u130c"+
		"\u0001\u0000\u0000\u0000\u130a\u1308\u0001\u0000\u0000\u0000\u130a\u130b"+
		"\u0001\u0000\u0000\u0000\u130b\u130e\u0001\u0000\u0000\u0000\u130c\u130a"+
		"\u0001\u0000\u0000\u0000\u130d\u12ec\u0001\u0000\u0000\u0000\u130d\u130e"+
		"\u0001\u0000\u0000\u0000\u130e\u130f\u0001\u0000\u0000\u0000\u130f\u1311"+
		"\u0005\u0197\u0000\u0000\u1310\u1312\u0003\u0250\u0128\u0000\u1311\u1310"+
		"\u0001\u0000\u0000\u0000\u1311\u1312\u0001\u0000\u0000\u0000\u1312\u018f"+
		"\u0001\u0000\u0000\u0000\u1313\u1316\u0005\u0017\u0000\u0000\u1314\u1317"+
		"\u0003\u0250\u0128\u0000\u1315\u1317\u0003\u02ba\u015d\u0000\u1316\u1314"+
		"\u0001\u0000\u0000\u0000\u1316\u1315\u0001\u0000\u0000\u0000\u1316\u1317"+
		"\u0001\u0000\u0000\u0000\u1317\u1319\u0001\u0000\u0000\u0000\u1318\u131a"+
		"\u0003\u01ae\u00d7\u0000\u1319\u1318\u0001\u0000\u0000\u0000\u131a\u131b"+
		"\u0001\u0000\u0000\u0000\u131b\u1319\u0001\u0000\u0000\u0000\u131b\u131c"+
		"\u0001\u0000\u0000\u0000\u131c\u1323\u0001\u0000\u0000\u0000\u131d\u131f"+
		"\u00056\u0000\u0000\u131e\u1320\u0003\u01ac\u00d6\u0000\u131f\u131e\u0001"+
		"\u0000\u0000\u0000\u1320\u1321\u0001\u0000\u0000\u0000\u1321\u131f\u0001"+
		"\u0000\u0000\u0000\u1321\u1322\u0001\u0000\u0000\u0000\u1322\u1324\u0001"+
		"\u0000\u0000\u0000\u1323\u131d\u0001\u0000\u0000\u0000\u1323\u1324\u0001"+
		"\u0000\u0000\u0000\u1324\u1325\u0001\u0000\u0000\u0000\u1325\u1326\u0005"+
		"\u0197\u0000\u0000\u1326\u1327\u0005\u0017\u0000\u0000\u1327\u0191\u0001"+
		"\u0000\u0000\u0000\u1328\u1329\u0005M\u0000\u0000\u1329\u132a\u0003\u02ba"+
		"\u015d\u0000\u132a\u132c\u0005\u00ae\u0000\u0000\u132b\u132d\u0003\u01ac"+
		"\u00d6\u0000\u132c\u132b\u0001\u0000\u0000\u0000\u132d\u132e\u0001\u0000"+
		"\u0000\u0000\u132e\u132c\u0001\u0000\u0000\u0000\u132e\u132f\u0001\u0000"+
		"\u0000\u0000\u132f\u1333\u0001\u0000\u0000\u0000\u1330\u1332\u0003\u01b0"+
		"\u00d8\u0000\u1331\u1330\u0001\u0000\u0000\u0000\u1332\u1335\u0001\u0000"+
		"\u0000\u0000\u1333\u1331\u0001\u0000\u0000\u0000\u1333\u1334\u0001\u0000"+
		"\u0000\u0000\u1334\u133c\u0001\u0000\u0000\u0000\u1335\u1333\u0001\u0000"+
		"\u0000\u0000\u1336\u1338\u00056\u0000\u0000\u1337\u1339\u0003\u01ac\u00d6"+
		"\u0000\u1338\u1337\u0001\u0000\u0000\u0000\u1339\u133a\u0001\u0000\u0000"+
		"\u0000\u133a\u1338\u0001\u0000\u0000\u0000\u133a\u133b\u0001\u0000\u0000"+
		"\u0000\u133b\u133d\u0001\u0000\u0000\u0000\u133c\u1336\u0001\u0000\u0000"+
		"\u0000\u133c\u133d\u0001\u0000\u0000\u0000\u133d\u133e\u0001\u0000\u0000"+
		"\u0000\u133e\u133f\u0005\u0197\u0000\u0000\u133f\u1340\u0005M\u0000\u0000"+
		"\u1340\u0193\u0001\u0000\u0000\u0000\u1341\u1342\u0005Y\u0000\u0000\u1342"+
		"\u1343\u0003\u0250\u0128\u0000\u1343\u0195\u0001\u0000\u0000\u0000\u1344"+
		"\u1345\u0005`\u0000\u0000\u1345\u1346\u0003\u0250\u0128\u0000\u1346\u0197"+
		"\u0001\u0000\u0000\u0000\u1347\u1348\u0003\u0250\u0128\u0000\u1348\u1349"+
		"\u0005\u048d\u0000\u0000\u1349\u134b\u0001\u0000\u0000\u0000\u134a\u1347"+
		"\u0001\u0000\u0000\u0000\u134a\u134b\u0001\u0000\u0000\u0000\u134b\u134c"+
		"\u0001\u0000\u0000\u0000\u134c\u134e\u0005i\u0000\u0000\u134d\u134f\u0003"+
		"\u01ac\u00d6\u0000\u134e\u134d\u0001\u0000\u0000\u0000\u134f\u1350\u0001"+
		"\u0000\u0000\u0000\u1350\u134e\u0001\u0000\u0000\u0000\u1350\u1351\u0001"+
		"\u0000\u0000\u0000\u1351\u1352\u0001\u0000\u0000\u0000\u1352\u1353\u0005"+
		"\u0197\u0000\u0000\u1353\u1355\u0005i\u0000\u0000\u1354\u1356\u0003\u0250"+
		"\u0128\u0000\u1355\u1354\u0001\u0000\u0000\u0000\u1355\u1356\u0001\u0000"+
		"\u0000\u0000\u1356\u0199\u0001\u0000\u0000\u0000\u1357\u1358\u0003\u0250"+
		"\u0128\u0000\u1358\u1359\u0005\u048d\u0000\u0000\u1359\u135b\u0001\u0000"+
		"\u0000\u0000\u135a\u1357\u0001\u0000\u0000\u0000\u135a\u135b\u0001\u0000"+
		"\u0000\u0000\u135b\u135c\u0001\u0000\u0000\u0000\u135c\u135e\u0005\u008d"+
		"\u0000\u0000\u135d\u135f\u0003\u01ac\u00d6\u0000\u135e\u135d\u0001\u0000"+
		"\u0000\u0000\u135f\u1360\u0001\u0000\u0000\u0000\u1360\u135e\u0001\u0000"+
		"\u0000\u0000\u1360\u1361\u0001\u0000\u0000\u0000\u1361\u1362\u0001\u0000"+
		"\u0000\u0000\u1362\u1363\u0005\u029b\u0000\u0000\u1363\u1364\u0003\u02ba"+
		"\u015d\u0000\u1364\u1365\u0005\u0197\u0000\u0000\u1365\u1367\u0005\u008d"+
		"\u0000\u0000\u1366\u1368\u0003\u0250\u0128\u0000\u1367\u1366\u0001\u0000"+
		"\u0000\u0000\u1367\u1368\u0001\u0000\u0000\u0000\u1368\u019b\u0001\u0000"+
		"\u0000\u0000\u1369\u136a\u0005\u0093\u0000\u0000\u136a\u136b\u0003\u02ba"+
		"\u015d\u0000\u136b\u019d\u0001\u0000\u0000\u0000\u136c\u136d\u0003\u0250"+
		"\u0128\u0000\u136d\u136e\u0005\u048d\u0000\u0000\u136e\u1370\u0001\u0000"+
		"\u0000\u0000\u136f\u136c\u0001\u0000\u0000\u0000\u136f\u1370\u0001\u0000"+
		"\u0000\u0000\u1370\u1371\u0001\u0000\u0000\u0000\u1371\u1372\u0005\u00bf"+
		"\u0000\u0000\u1372\u1373\u0003\u02ba\u015d\u0000\u1373\u1375\u0005\u018f"+
		"\u0000\u0000\u1374\u1376\u0003\u01ac\u00d6\u0000\u1375\u1374\u0001\u0000"+
		"\u0000\u0000\u1376\u1377\u0001\u0000\u0000\u0000\u1377\u1375\u0001\u0000"+
		"\u0000\u0000\u1377\u1378\u0001\u0000\u0000\u0000\u1378\u1379\u0001\u0000"+
		"\u0000\u0000\u1379\u137a\u0005\u0197\u0000\u0000\u137a\u137c\u0005\u00bf"+
		"\u0000\u0000\u137b\u137d\u0003\u0250\u0128\u0000\u137c\u137b\u0001\u0000"+
		"\u0000\u0000\u137c\u137d\u0001\u0000\u0000\u0000\u137d\u019f\u0001\u0000"+
		"\u0000\u0000\u137e\u137f\u0005\u0169\u0000\u0000\u137f\u138e\u0003\u0250"+
		"\u0128\u0000\u1380\u1385\u0005@\u0000\u0000\u1381\u1383\u0005\u0209\u0000"+
		"\u0000\u1382\u1381\u0001\u0000\u0000\u0000\u1382\u1383\u0001\u0000\u0000"+
		"\u0000\u1383\u1384\u0001\u0000\u0000\u0000\u1384\u1386\u0005D\u0000\u0000"+
		"\u1385\u1382\u0001\u0000\u0000\u0000\u1385\u1386\u0001\u0000\u0000\u0000"+
		"\u1386\u1387\u0001\u0000\u0000\u0000\u1387\u1388\u0003\u0250\u0128\u0000"+
		"\u1388\u1389\u0005W\u0000\u0000\u1389\u138a\u0003\u0272\u0139\u0000\u138a"+
		"\u138e\u0001\u0000\u0000\u0000\u138b\u138c\u0005\u021c\u0000\u0000\u138c"+
		"\u138e\u0003\u0250\u0128\u0000\u138d\u137e\u0001\u0000\u0000\u0000\u138d"+
		"\u1380\u0001\u0000\u0000\u0000\u138d\u138b\u0001\u0000\u0000\u0000\u138e"+
		"\u01a1\u0001\u0000\u0000\u0000\u138f\u1390\u0005*\u0000\u0000\u1390\u1391"+
		"\u0003\u0272\u0139\u0000\u1391\u1394\u0003\u0264\u0132\u0000\u1392\u1393"+
		"\u0005+\u0000\u0000\u1393\u1395\u0003\u02ba\u015d\u0000\u1394\u1392\u0001"+
		"\u0000\u0000\u0000\u1394\u1395\u0001\u0000\u0000\u0000\u1395\u01a3\u0001"+
		"\u0000\u0000\u0000\u1396\u1397\u0005*\u0000\u0000\u1397\u1398\u0003\u0250"+
		"\u0128\u0000\u1398\u1399\u0005\u001e\u0000\u0000\u1399\u13a0\u0005A\u0000"+
		"\u0000\u139a\u13a1\u0003\u0256\u012b\u0000\u139b\u139d\u0005\u00a2\u0000"+
		"\u0000\u139c\u139e\u0005\u02a1\u0000\u0000\u139d\u139c\u0001\u0000\u0000"+
		"\u0000\u139d\u139e\u0001\u0000\u0000\u0000\u139e\u139f\u0001\u0000\u0000"+
		"\u0000\u139f\u13a1\u0005\u0491\u0000\u0000\u13a0\u139a\u0001\u0000\u0000"+
		"\u0000\u13a0\u139b\u0001\u0000\u0000\u0000\u13a1\u01a5\u0001\u0000\u0000"+
		"\u0000\u13a2\u13a3\u0005*\u0000\u0000\u13a3\u13a4\u0003\u0250\u0128\u0000"+
		"\u13a4\u13a5\u0005\'\u0000\u0000\u13a5\u13a6\u0005A\u0000\u0000\u13a6"+
		"\u13a7\u0003\u00d2i\u0000\u13a7\u01a7\u0001\u0000\u0000\u0000\u13a8\u13a9"+
		"\u0005*\u0000\u0000\u13a9\u13aa\u0007D\u0000\u0000\u13aa\u13ab\u0005\u01ba"+
		"\u0000\u0000\u13ab\u13ac\u0005A\u0000\u0000\u13ac\u13b1\u0003\u01aa\u00d5"+
		"\u0000\u13ad\u13ae\u0005\u0484\u0000\u0000\u13ae\u13b0\u0003\u01aa\u00d5"+
		"\u0000\u13af\u13ad\u0001\u0000\u0000\u0000\u13b0\u13b3\u0001\u0000\u0000"+
		"\u0000\u13b1\u13af\u0001\u0000\u0000\u0000\u13b1\u13b2\u0001\u0000\u0000"+
		"\u0000\u13b2\u13b4\u0001\u0000\u0000\u0000\u13b3\u13b1\u0001\u0000\u0000"+
		"\u0000\u13b4\u13b5\u0003\u018c\u00c6\u0000\u13b5\u01a9\u0001\u0000\u0000"+
		"\u0000\u13b6\u13c2\u0003\u0256\u012b\u0000\u13b7\u13b9\u0005\u00a2\u0000"+
		"\u0000\u13b8\u13ba\u0005\u02a1\u0000\u0000\u13b9\u13b8\u0001\u0000\u0000"+
		"\u0000\u13b9\u13ba\u0001\u0000\u0000\u0000\u13ba\u13bb\u0001\u0000\u0000"+
		"\u0000\u13bb\u13c2\u0005\u0491\u0000\u0000\u13bc\u13c2\u0003\u0250\u0128"+
		"\u0000\u13bd\u13c2\u0005\u00a3\u0000\u0000\u13be\u13bf\u0005r\u0000\u0000"+
		"\u13bf\u13c2\u0005\u01b3\u0000\u0000\u13c0\u13c2\u0005\u00a1\u0000\u0000"+
		"\u13c1\u13b6\u0001\u0000\u0000\u0000\u13c1\u13b7\u0001\u0000\u0000\u0000"+
		"\u13c1\u13bc\u0001\u0000\u0000\u0000\u13c1\u13bd\u0001\u0000\u0000\u0000"+
		"\u13c1\u13be\u0001\u0000\u0000\u0000\u13c1\u13c0\u0001\u0000\u0000\u0000"+
		"\u13c2\u01ab\u0001\u0000\u0000\u0000\u13c3\u13c6\u0003\u0014\n\u0000\u13c4"+
		"\u13c6\u0003\u0004\u0002\u0000\u13c5\u13c3\u0001\u0000\u0000\u0000\u13c5"+
		"\u13c4\u0001\u0000\u0000\u0000\u13c6\u13c7\u0001\u0000\u0000\u0000\u13c7"+
		"\u13c8\u0005\u0485\u0000\u0000\u13c8\u01ad\u0001\u0000\u0000\u0000\u13c9"+
		"\u13cc\u0005\u00bd\u0000\u0000\u13ca\u13cd\u0003\u0262\u0131\u0000\u13cb"+
		"\u13cd\u0003\u02ba\u015d\u0000\u13cc\u13ca\u0001\u0000\u0000\u0000\u13cc"+
		"\u13cb\u0001\u0000\u0000\u0000\u13cd\u13ce\u0001\u0000\u0000\u0000\u13ce"+
		"\u13d0\u0005\u00ae\u0000\u0000\u13cf\u13d1\u0003\u01ac\u00d6\u0000\u13d0"+
		"\u13cf\u0001\u0000\u0000\u0000\u13d1\u13d2\u0001\u0000\u0000\u0000\u13d2"+
		"\u13d0\u0001\u0000\u0000\u0000\u13d2\u13d3\u0001\u0000\u0000\u0000\u13d3"+
		"\u01af\u0001\u0000\u0000\u0000\u13d4\u13d5\u00057\u0000\u0000\u13d5\u13d6"+
		"\u0003\u02ba\u015d\u0000\u13d6\u13d8\u0005\u00ae\u0000\u0000\u13d7\u13d9"+
		"\u0003\u01ac\u00d6\u0000\u13d8\u13d7\u0001\u0000\u0000\u0000\u13d9\u13da"+
		"\u0001\u0000\u0000\u0000\u13da\u13d8\u0001\u0000\u0000\u0000\u13da\u13db"+
		"\u0001\u0000\u0000\u0000\u13db\u01b1\u0001\u0000\u0000\u0000\u13dc\u13dd"+
		"\u0005\u0007\u0000\u0000\u13dd\u13de\u0005\u029d\u0000\u0000\u13de\u13e3"+
		"\u0003\u01c6\u00e3\u0000\u13df\u13e0\u0005\u0484\u0000\u0000\u13e0\u13e2"+
		"\u0003\u01c6\u00e3\u0000\u13e1\u13df\u0001\u0000\u0000\u0000\u13e2\u13e5"+
		"\u0001\u0000\u0000\u0000\u13e3\u13e1\u0001\u0000\u0000\u0000\u13e3\u13e4"+
		"\u0001\u0000\u0000\u0000\u13e4\u1419\u0001\u0000\u0000\u0000\u13e5\u13e3"+
		"\u0001\u0000\u0000\u0000\u13e6\u13e7\u0005\u0007\u0000\u0000\u13e7\u13e9"+
		"\u0005\u029d\u0000\u0000\u13e8\u13ea\u0003\u0288\u0144\u0000\u13e9\u13e8"+
		"\u0001\u0000\u0000\u0000\u13e9\u13ea\u0001\u0000\u0000\u0000\u13ea\u13eb"+
		"\u0001\u0000\u0000\u0000\u13eb\u13f0\u0003\u01c8\u00e4\u0000\u13ec\u13ed"+
		"\u0005\u0484\u0000\u0000\u13ed\u13ef\u0003\u01c8\u00e4\u0000\u13ee\u13ec"+
		"\u0001\u0000\u0000\u0000\u13ef\u13f2\u0001\u0000\u0000\u0000\u13f0\u13ee"+
		"\u0001\u0000\u0000\u0000\u13f0\u13f1\u0001\u0000\u0000\u0000\u13f1\u1401"+
		"\u0001\u0000\u0000\u0000\u13f2\u13f0\u0001\u0000\u0000\u0000\u13f3\u13ff"+
		"\u0005\u008f\u0000\u0000\u13f4\u1400\u0005\u0212\u0000\u0000\u13f5\u13fc"+
		"\u0003\u01cc\u00e6\u0000\u13f6\u13f8\u0005\n\u0000\u0000\u13f7\u13f6\u0001"+
		"\u0000\u0000\u0000\u13f7\u13f8\u0001\u0000\u0000\u0000\u13f8\u13f9\u0001"+
		"\u0000\u0000\u0000\u13f9\u13fb\u0003\u01cc\u00e6\u0000\u13fa\u13f7\u0001"+
		"\u0000\u0000\u0000\u13fb\u13fe\u0001\u0000\u0000\u0000\u13fc\u13fa\u0001"+
		"\u0000\u0000\u0000\u13fc\u13fd\u0001\u0000\u0000\u0000\u13fd\u1400\u0001"+
		"\u0000\u0000\u0000\u13fe\u13fc\u0001\u0000\u0000\u0000\u13ff\u13f4\u0001"+
		"\u0000\u0000\u0000\u13ff\u13f5\u0001\u0000\u0000\u0000\u1400\u1402\u0001"+
		"\u0000\u0000\u0000\u1401\u13f3\u0001\u0000\u0000\u0000\u1401\u1402\u0001"+
		"\u0000\u0000\u0000\u1402\u1409\u0001\u0000\u0000\u0000\u1403\u1405\u0005"+
		"\u00c0\u0000\u0000\u1404\u1406\u0003\u01ce\u00e7\u0000\u1405\u1404\u0001"+
		"\u0000\u0000\u0000\u1406\u1407\u0001\u0000\u0000\u0000\u1407\u1405\u0001"+
		"\u0000\u0000\u0000\u1407\u1408\u0001\u0000\u0000\u0000\u1408\u140a\u0001"+
		"\u0000\u0000\u0000\u1409\u1403\u0001\u0000\u0000\u0000\u1409\u140a\u0001"+
		"\u0000\u0000\u0000\u140a\u140f\u0001\u0000\u0000\u0000\u140b\u140e\u0003"+
		"\u01d0\u00e8\u0000\u140c\u140e\u0003\u01d2\u00e9\u0000\u140d\u140b\u0001"+
		"\u0000\u0000\u0000\u140d\u140c\u0001\u0000\u0000\u0000\u140e\u1411\u0001"+
		"\u0000\u0000\u0000\u140f\u140d\u0001\u0000\u0000\u0000\u140f\u1410\u0001"+
		"\u0000\u0000\u0000\u1410\u1416\u0001\u0000\u0000\u0000\u1411\u140f\u0001"+
		"\u0000\u0000\u0000\u1412\u1413\u0005\u0170\u0000\u0000\u1413\u1417\u0005"+
		"\u0491\u0000\u0000\u1414\u1415\u0005\u000e\u0000\u0000\u1415\u1417\u0005"+
		"\u0491\u0000\u0000\u1416\u1412\u0001\u0000\u0000\u0000\u1416\u1414\u0001"+
		"\u0000\u0000\u0000\u1416\u1417\u0001\u0000\u0000\u0000\u1417\u1419\u0001"+
		"\u0000\u0000\u0000\u1418\u13dc\u0001\u0000\u0000\u0000\u1418\u13e6\u0001"+
		"\u0000\u0000\u0000\u1419\u01b3\u0001\u0000\u0000\u0000\u141a\u141b\u0005"+
		"\"\u0000\u0000\u141b\u141c\u0005\u029d\u0000\u0000\u141c\u1421\u0003\u01c8"+
		"\u00e4\u0000\u141d\u141e\u0005\u0484\u0000\u0000\u141e\u1420\u0003\u01c8"+
		"\u00e4\u0000\u141f\u141d\u0001\u0000\u0000\u0000\u1420\u1423\u0001\u0000"+
		"\u0000\u0000\u1421\u141f\u0001\u0000\u0000\u0000\u1421\u1422\u0001\u0000"+
		"\u0000\u0000\u1422\u1457\u0001\u0000\u0000\u0000\u1423\u1421\u0001\u0000"+
		"\u0000\u0000\u1424\u1425\u0005\"\u0000\u0000\u1425\u1427\u0005\u029d\u0000"+
		"\u0000\u1426\u1428\u0003\u028a\u0145\u0000\u1427\u1426\u0001\u0000\u0000"+
		"\u0000\u1427\u1428\u0001\u0000\u0000\u0000\u1428\u1429\u0001\u0000\u0000"+
		"\u0000\u1429\u142e\u0003\u01c8\u00e4\u0000\u142a\u142b\u0005\u0484\u0000"+
		"\u0000\u142b\u142d\u0003\u01c8\u00e4\u0000\u142c\u142a\u0001\u0000\u0000"+
		"\u0000\u142d\u1430\u0001\u0000\u0000\u0000\u142e\u142c\u0001\u0000\u0000"+
		"\u0000\u142e\u142f\u0001\u0000\u0000\u0000\u142f\u143f\u0001\u0000\u0000"+
		"\u0000\u1430\u142e\u0001\u0000\u0000\u0000\u1431\u143d\u0005\u008f\u0000"+
		"\u0000\u1432\u143e\u0005\u0212\u0000\u0000\u1433\u143a\u0003\u01cc\u00e6"+
		"\u0000\u1434\u1436\u0005\n\u0000\u0000\u1435\u1434\u0001\u0000\u0000\u0000"+
		"\u1435\u1436\u0001\u0000\u0000\u0000\u1436\u1437\u0001\u0000\u0000\u0000"+
		"\u1437\u1439\u0003\u01cc\u00e6\u0000\u1438\u1435\u0001\u0000\u0000\u0000"+
		"\u1439\u143c\u0001\u0000\u0000\u0000\u143a\u1438\u0001\u0000\u0000\u0000"+
		"\u143a\u143b\u0001\u0000\u0000\u0000\u143b\u143e\u0001\u0000\u0000\u0000"+
		"\u143c\u143a\u0001\u0000\u0000\u0000\u143d\u1432\u0001\u0000\u0000\u0000"+
		"\u143d\u1433\u0001\u0000\u0000\u0000\u143e\u1440\u0001\u0000\u0000\u0000"+
		"\u143f\u1431\u0001\u0000\u0000\u0000\u143f\u1440\u0001\u0000\u0000\u0000"+
		"\u1440\u1447\u0001\u0000\u0000\u0000\u1441\u1443\u0005\u00c0\u0000\u0000"+
		"\u1442\u1444\u0003\u01ce\u00e7\u0000\u1443\u1442\u0001\u0000\u0000\u0000"+
		"\u1444\u1445\u0001\u0000\u0000\u0000\u1445\u1443\u0001\u0000\u0000\u0000"+
		"\u1445\u1446\u0001\u0000\u0000\u0000\u1446\u1448\u0001\u0000\u0000\u0000"+
		"\u1447\u1441\u0001\u0000\u0000\u0000\u1447\u1448\u0001\u0000\u0000\u0000"+
		"\u1448\u144d\u0001\u0000\u0000\u0000\u1449\u144c\u0003\u01d0\u00e8\u0000"+
		"\u144a\u144c\u0003\u01d2\u00e9\u0000\u144b\u1449\u0001\u0000\u0000\u0000"+
		"\u144b\u144a\u0001\u0000\u0000\u0000\u144c\u144f\u0001\u0000\u0000\u0000"+
		"\u144d\u144b\u0001\u0000\u0000\u0000\u144d\u144e\u0001\u0000\u0000\u0000"+
		"\u144e\u1454\u0001\u0000\u0000\u0000\u144f\u144d\u0001\u0000\u0000\u0000"+
		"\u1450\u1451\u0005\u0170\u0000\u0000\u1451\u1455\u0005\u0491\u0000\u0000"+
		"\u1452\u1453\u0005\u000e\u0000\u0000\u1453\u1455\u0005\u0491\u0000\u0000"+
		"\u1454\u1450\u0001\u0000\u0000\u0000\u1454\u1452\u0001\u0000\u0000\u0000"+
		"\u1454\u1455\u0001\u0000\u0000\u0000\u1455\u1457\u0001\u0000\u0000\u0000"+
		"\u1456\u141a\u0001\u0000\u0000\u0000\u1456\u1424\u0001\u0000\u0000\u0000"+
		"\u1457\u01b5\u0001\u0000\u0000\u0000\u1458\u1459\u00054\u0000\u0000\u1459"+
		"\u145b\u0005\u029d\u0000\u0000\u145a\u145c\u0003\u0288\u0144\u0000\u145b"+
		"\u145a\u0001\u0000\u0000\u0000\u145b\u145c\u0001\u0000\u0000\u0000\u145c"+
		"\u145d\u0001\u0000\u0000\u0000\u145d\u1462\u0003\u023a\u011d\u0000\u145e"+
		"\u145f\u0005\u0484\u0000\u0000\u145f\u1461\u0003\u023a\u011d\u0000\u1460"+
		"\u145e\u0001\u0000\u0000\u0000\u1461\u1464\u0001\u0000\u0000\u0000\u1462"+
		"\u1460\u0001\u0000\u0000\u0000\u1462\u1463\u0001\u0000\u0000\u0000\u1463"+
		"\u01b7\u0001\u0000\u0000\u0000\u1464\u1462\u0001\u0000\u0000\u0000\u1465"+
		"\u1466\u0005H\u0000\u0000\u1466\u146b\u0003\u01d4\u00ea\u0000\u1467\u1468"+
		"\u0005\u0484\u0000\u0000\u1468\u146a\u0003\u01d4\u00ea\u0000\u1469\u1467"+
		"\u0001\u0000\u0000\u0000\u146a\u146d\u0001\u0000\u0000\u0000\u146b\u1469"+
		"\u0001\u0000\u0000\u0000\u146b\u146c\u0001\u0000\u0000\u0000\u146c\u146e"+
		"\u0001\u0000\u0000\u0000\u146d\u146b\u0001\u0000\u0000\u0000\u146e\u1470"+
		"\u0005v\u0000\u0000\u146f\u1471\u0007E\u0000\u0000\u1470\u146f\u0001\u0000"+
		"\u0000\u0000\u1470\u1471\u0001\u0000\u0000\u0000\u1471\u1472\u0001\u0000"+
		"\u0000\u0000\u1472\u1473\u0003\u01d8\u00ec\u0000\u1473\u1474\u0005\u00af"+
		"\u0000\u0000\u1474\u1479\u0003\u01c8\u00e4\u0000\u1475\u1476\u0005\u0484"+
		"\u0000\u0000\u1476\u1478\u0003\u01c8\u00e4\u0000\u1477\u1475\u0001\u0000"+
		"\u0000\u0000\u1478\u147b\u0001\u0000\u0000\u0000\u1479\u1477\u0001\u0000"+
		"\u0000\u0000\u1479\u147a\u0001\u0000\u0000\u0000\u147a\u148a\u0001\u0000"+
		"\u0000\u0000\u147b\u1479\u0001\u0000\u0000\u0000\u147c\u1488\u0005\u008f"+
		"\u0000\u0000\u147d\u1489\u0005\u0212\u0000\u0000\u147e\u1485\u0003\u01cc"+
		"\u00e6\u0000\u147f\u1481\u0005\n\u0000\u0000\u1480\u147f\u0001\u0000\u0000"+
		"\u0000\u1480\u1481\u0001\u0000\u0000\u0000\u1481\u1482\u0001\u0000\u0000"+
		"\u0000\u1482\u1484\u0003\u01cc\u00e6\u0000\u1483\u1480\u0001\u0000\u0000"+
		"\u0000\u1484\u1487\u0001\u0000\u0000\u0000\u1485\u1483\u0001\u0000\u0000"+
		"\u0000\u1485\u1486\u0001\u0000\u0000\u0000\u1486\u1489\u0001\u0000\u0000"+
		"\u0000\u1487\u1485\u0001\u0000\u0000\u0000\u1488\u147d\u0001\u0000\u0000"+
		"\u0000\u1488\u147e\u0001\u0000\u0000\u0000\u1489\u148b\u0001\u0000\u0000"+
		"\u0000\u148a\u147c\u0001\u0000\u0000\u0000\u148a\u148b\u0001\u0000\u0000"+
		"\u0000\u148b\u1495\u0001\u0000\u0000\u0000\u148c\u1492\u0005\u00c0\u0000"+
		"\u0000\u148d\u148e\u0005H\u0000\u0000\u148e\u1491\u0005x\u0000\u0000\u148f"+
		"\u1491\u0003\u01ce\u00e7\u0000\u1490\u148d\u0001\u0000\u0000\u0000\u1490"+
		"\u148f\u0001\u0000\u0000\u0000\u1491\u1494\u0001\u0000\u0000\u0000\u1492"+
		"\u1490\u0001\u0000\u0000\u0000\u1492\u1493\u0001\u0000\u0000\u0000\u1493"+
		"\u1496\u0001\u0000\u0000\u0000\u1494\u1492\u0001\u0000\u0000\u0000\u1495"+
		"\u148c\u0001\u0000\u0000\u0000\u1495\u1496\u0001\u0000\u0000\u0000\u1496"+
		"\u149d\u0001\u0000\u0000\u0000\u1497\u1498\u0005\f\u0000\u0000\u1498\u1499"+
		"\u0003\u023a\u011d\u0000\u1499\u149a\u0005\u00c0\u0000\u0000\u149a\u149b"+
		"\u0005\u0256\u0000\u0000\u149b\u149c\u0003\u01ba\u00dd\u0000\u149c\u149e"+
		"\u0001\u0000\u0000\u0000\u149d\u1497\u0001\u0000\u0000\u0000\u149d\u149e"+
		"\u0001\u0000\u0000\u0000\u149e\u14c3\u0001\u0000\u0000\u0000\u149f\u14a2"+
		"\u0005H\u0000\u0000\u14a0\u14a3\u0003\u023a\u011d\u0000\u14a1\u14a3\u0003"+
		"\u0250\u0128\u0000\u14a2\u14a0\u0001\u0000\u0000\u0000\u14a2\u14a1\u0001"+
		"\u0000\u0000\u0000\u14a3\u14ab\u0001\u0000\u0000\u0000\u14a4\u14a7\u0005"+
		"\u0484\u0000\u0000\u14a5\u14a8\u0003\u023a\u011d\u0000\u14a6\u14a8\u0003"+
		"\u0250\u0128\u0000\u14a7\u14a5\u0001\u0000\u0000\u0000\u14a7\u14a6\u0001"+
		"\u0000\u0000\u0000\u14a8\u14aa\u0001\u0000\u0000\u0000\u14a9\u14a4\u0001"+
		"\u0000\u0000\u0000\u14aa\u14ad\u0001\u0000\u0000\u0000\u14ab\u14a9\u0001"+
		"\u0000\u0000\u0000\u14ab\u14ac\u0001\u0000\u0000\u0000\u14ac\u14ae\u0001"+
		"\u0000\u0000\u0000\u14ad\u14ab\u0001\u0000\u0000\u0000\u14ae\u14b1\u0005"+
		"\u00af\u0000\u0000\u14af\u14b2\u0003\u023a\u011d\u0000\u14b0\u14b2\u0003"+
		"\u0250\u0128\u0000\u14b1\u14af\u0001\u0000\u0000\u0000\u14b1\u14b0\u0001"+
		"\u0000\u0000\u0000\u14b2\u14ba\u0001\u0000\u0000\u0000\u14b3\u14b6\u0005"+
		"\u0484\u0000\u0000\u14b4\u14b7\u0003\u023a\u011d\u0000\u14b5\u14b7\u0003"+
		"\u0250\u0128\u0000\u14b6\u14b4\u0001\u0000\u0000\u0000\u14b6\u14b5\u0001"+
		"\u0000\u0000\u0000\u14b7\u14b9\u0001\u0000\u0000\u0000\u14b8\u14b3\u0001"+
		"\u0000\u0000\u0000\u14b9\u14bc\u0001\u0000\u0000\u0000\u14ba\u14b8\u0001"+
		"\u0000\u0000\u0000\u14ba\u14bb\u0001\u0000\u0000\u0000\u14bb\u14c0\u0001"+
		"\u0000\u0000\u0000\u14bc\u14ba\u0001\u0000\u0000\u0000\u14bd\u14be\u0005"+
		"\u00c0\u0000\u0000\u14be\u14bf\u0005\u02c3\u0000\u0000\u14bf\u14c1\u0005"+
		"x\u0000\u0000\u14c0\u14bd\u0001\u0000\u0000\u0000\u14c0\u14c1\u0001\u0000"+
		"\u0000\u0000\u14c1\u14c3\u0001\u0000\u0000\u0000\u14c2\u1465\u0001\u0000"+
		"\u0000\u0000\u14c2\u149f\u0001\u0000\u0000\u0000\u14c3\u01b9\u0001\u0000"+
		"\u0000\u0000\u14c4\u14db\u0005+\u0000\u0000\u14c5\u14db\u0005\u0212\u0000"+
		"\u0000\u14c6\u14d0\u0005\u0006\u0000\u0000\u14c7\u14c8\u0005;\u0000\u0000"+
		"\u14c8\u14cd\u0003\u023a\u011d\u0000\u14c9\u14ca\u0005\u0484\u0000\u0000"+
		"\u14ca\u14cc\u0003\u023a\u011d\u0000\u14cb\u14c9\u0001\u0000\u0000\u0000"+
		"\u14cc\u14cf\u0001\u0000\u0000\u0000\u14cd\u14cb\u0001\u0000\u0000\u0000"+
		"\u14cd\u14ce\u0001\u0000\u0000\u0000\u14ce\u14d1\u0001\u0000\u0000\u0000"+
		"\u14cf\u14cd\u0001\u0000\u0000\u0000\u14d0\u14c7\u0001\u0000\u0000\u0000"+
		"\u14d0\u14d1\u0001\u0000\u0000\u0000\u14d1\u14db\u0001\u0000\u0000\u0000"+
		"\u14d2\u14d7\u0003\u023a\u011d\u0000\u14d3\u14d4\u0005\u0484\u0000\u0000"+
		"\u14d4\u14d6\u0003\u023a\u011d\u0000\u14d5\u14d3\u0001\u0000\u0000\u0000"+
		"\u14d6\u14d9\u0001\u0000\u0000\u0000\u14d7\u14d5\u0001\u0000\u0000\u0000"+
		"\u14d7\u14d8\u0001\u0000\u0000\u0000\u14d8\u14db\u0001\u0000\u0000\u0000"+
		"\u14d9\u14d7\u0001\u0000\u0000\u0000\u14da\u14c4\u0001\u0000\u0000\u0000"+
		"\u14da\u14c5\u0001\u0000\u0000\u0000\u14da\u14c6\u0001\u0000\u0000\u0000"+
		"\u14da\u14d2\u0001\u0000\u0000\u0000\u14db\u01bb\u0001\u0000\u0000\u0000"+
		"\u14dc\u14dd\u0005H\u0000\u0000\u14dd\u14de\u0005\u0237\u0000\u0000\u14de"+
		"\u14df\u0005v\u0000\u0000\u14df\u14e0\u0003\u023a\u011d\u0000\u14e0\u14e1"+
		"\u0005\u00af\u0000\u0000\u14e1\u14e6\u0003\u023a\u011d\u0000\u14e2\u14e3"+
		"\u0005\u0484\u0000\u0000\u14e3\u14e5\u0003\u023a\u011d\u0000\u14e4\u14e2"+
		"\u0001\u0000\u0000\u0000\u14e5\u14e8\u0001\u0000\u0000\u0000\u14e6\u14e4"+
		"\u0001\u0000\u0000\u0000\u14e6\u14e7\u0001\u0000\u0000\u0000\u14e7\u14ec"+
		"\u0001\u0000\u0000\u0000\u14e8\u14e6\u0001\u0000\u0000\u0000\u14e9\u14ea"+
		"\u0005\u00c0\u0000\u0000\u14ea\u14eb\u0005H\u0000\u0000\u14eb\u14ed\u0005"+
		"x\u0000\u0000\u14ec\u14e9\u0001\u0000\u0000\u0000\u14ec\u14ed\u0001\u0000"+
		"\u0000\u0000\u14ed\u01bd\u0001\u0000\u0000\u0000\u14ee\u14ef\u0005\u008c"+
		"\u0000\u0000\u14ef\u14f0\u0005\u029d\u0000\u0000\u14f0\u14f5\u0003\u01da"+
		"\u00ed\u0000\u14f1\u14f2\u0005\u0484\u0000\u0000\u14f2\u14f4\u0003\u01da"+
		"\u00ed\u0000\u14f3\u14f1\u0001\u0000\u0000\u0000\u14f4\u14f7\u0001\u0000"+
		"\u0000\u0000\u14f5\u14f3\u0001\u0000\u0000\u0000\u14f5\u14f6\u0001\u0000"+
		"\u0000\u0000\u14f6\u01bf\u0001\u0000\u0000\u0000\u14f7\u14f5\u0001\u0000"+
		"\u0000\u0000\u14f8\u14f9\u0005\u0094\u0000\u0000\u14f9\u14fe\u0003\u01d4"+
		"\u00ea\u0000\u14fa\u14fb\u0005\u0484\u0000\u0000\u14fb\u14fd\u0003\u01d4"+
		"\u00ea\u0000\u14fc\u14fa\u0001\u0000\u0000\u0000\u14fd\u1500\u0001\u0000"+
		"\u0000\u0000\u14fe\u14fc\u0001\u0000\u0000\u0000\u14fe\u14ff\u0001\u0000"+
		"\u0000\u0000\u14ff\u1501\u0001\u0000\u0000\u0000\u1500\u14fe\u0001\u0000"+
		"\u0000\u0000\u1501\u1503\u0005v\u0000\u0000\u1502\u1504\u0007E\u0000\u0000"+
		"\u1503\u1502\u0001\u0000\u0000\u0000\u1503\u1504\u0001\u0000\u0000\u0000"+
		"\u1504\u1505\u0001\u0000\u0000\u0000\u1505\u1506\u0003\u01d8\u00ec\u0000"+
		"\u1506\u1507\u0005D\u0000\u0000\u1507\u150c\u0003\u023a\u011d\u0000\u1508"+
		"\u1509\u0005\u0484\u0000\u0000\u1509\u150b\u0003\u023a\u011d\u0000\u150a"+
		"\u1508\u0001\u0000\u0000\u0000\u150b\u150e\u0001\u0000\u0000\u0000\u150c"+
		"\u150a\u0001\u0000\u0000\u0000\u150c\u150d\u0001\u0000\u0000\u0000\u150d"+
		"\u1539\u0001\u0000\u0000\u0000\u150e\u150c\u0001\u0000\u0000\u0000\u150f"+
		"\u1510\u0005\u0094\u0000\u0000\u1510\u1512\u0005\u0006\u0000\u0000\u1511"+
		"\u1513\u0005\u02dc\u0000\u0000\u1512\u1511\u0001\u0000\u0000\u0000\u1512"+
		"\u1513\u0001\u0000\u0000\u0000\u1513\u1514\u0001\u0000\u0000\u0000\u1514"+
		"\u1515\u0005\u0484\u0000\u0000\u1515\u1516\u0005H\u0000\u0000\u1516\u1517"+
		"\u0005x\u0000\u0000\u1517\u1518\u0005D\u0000\u0000\u1518\u151d\u0003\u023a"+
		"\u011d\u0000\u1519\u151a\u0005\u0484\u0000\u0000\u151a\u151c\u0003\u023a"+
		"\u011d\u0000\u151b\u1519\u0001\u0000\u0000\u0000\u151c\u151f\u0001\u0000"+
		"\u0000\u0000\u151d\u151b\u0001\u0000\u0000\u0000\u151d\u151e\u0001\u0000"+
		"\u0000\u0000\u151e\u1539\u0001\u0000\u0000\u0000\u151f\u151d\u0001\u0000"+
		"\u0000\u0000\u1520\u1521\u0005\u0094\u0000\u0000\u1521\u1526\u0003\u0250"+
		"\u0128\u0000\u1522\u1523\u0005\u0484\u0000\u0000\u1523\u1525\u0003\u0250"+
		"\u0128\u0000\u1524\u1522\u0001\u0000\u0000\u0000\u1525\u1528\u0001\u0000"+
		"\u0000\u0000\u1526\u1524\u0001\u0000\u0000\u0000\u1526\u1527\u0001\u0000"+
		"\u0000\u0000\u1527\u1529\u0001\u0000\u0000\u0000\u1528\u1526\u0001\u0000"+
		"\u0000\u0000\u1529\u152c\u0005D\u0000\u0000\u152a\u152d\u0003\u023a\u011d"+
		"\u0000\u152b\u152d\u0003\u0250\u0128\u0000\u152c\u152a\u0001\u0000\u0000"+
		"\u0000\u152c\u152b\u0001\u0000\u0000\u0000\u152d\u1535\u0001\u0000\u0000"+
		"\u0000\u152e\u1531\u0005\u0484\u0000\u0000\u152f\u1532\u0003\u023a\u011d"+
		"\u0000\u1530\u1532\u0003\u0250\u0128\u0000\u1531\u152f\u0001\u0000\u0000"+
		"\u0000\u1531\u1530\u0001\u0000\u0000\u0000\u1532\u1534\u0001\u0000\u0000"+
		"\u0000\u1533\u152e\u0001\u0000\u0000\u0000\u1534\u1537\u0001\u0000\u0000"+
		"\u0000\u1535\u1533\u0001\u0000\u0000\u0000\u1535\u1536\u0001\u0000\u0000"+
		"\u0000\u1536\u1539\u0001\u0000\u0000\u0000\u1537\u1535\u0001\u0000\u0000"+
		"\u0000\u1538\u14f8\u0001\u0000\u0000\u0000\u1538\u150f\u0001\u0000\u0000"+
		"\u0000\u1538\u1520\u0001\u0000\u0000\u0000\u1539\u01c1\u0001\u0000\u0000"+
		"\u0000\u153a\u153b\u0005\u0094\u0000\u0000\u153b\u153c\u0005\u0237\u0000"+
		"\u0000\u153c\u153d\u0005v\u0000\u0000\u153d\u153e\u0003\u023a\u011d\u0000"+
		"\u153e\u153f\u0005D\u0000\u0000\u153f\u1544\u0003\u023a\u011d\u0000\u1540"+
		"\u1541\u0005\u0484\u0000\u0000\u1541\u1543\u0003\u023a\u011d\u0000\u1542"+
		"\u1540\u0001\u0000\u0000\u0000\u1543\u1546\u0001\u0000\u0000\u0000\u1544"+
		"\u1542\u0001\u0000\u0000\u0000\u1544\u1545\u0001\u0000\u0000\u0000\u1545"+
		"\u01c3\u0001\u0000\u0000\u0000\u1546\u1544\u0001\u0000\u0000\u0000\u1547"+
		"\u1548\u0005\u009a\u0000\u0000\u1548\u154b\u0005\u0228\u0000\u0000\u1549"+
		"\u154a\u0005A\u0000\u0000\u154a\u154c\u0003\u023a\u011d\u0000\u154b\u1549"+
		"\u0001\u0000\u0000\u0000\u154b\u154c\u0001\u0000\u0000\u0000\u154c\u154d"+
		"\u0001\u0000\u0000\u0000\u154d\u1550\u0005\u0479\u0000\u0000\u154e\u1551"+
		"\u0003\u02b4\u015a\u0000\u154f\u1551\u0005\u0491\u0000\u0000\u1550\u154e"+
		"\u0001\u0000\u0000\u0000\u1550\u154f\u0001\u0000\u0000\u0000\u1551\u01c5"+
		"\u0001\u0000\u0000\u0000\u1552\u1553\u0003\u023a\u011d\u0000\u1553\u1554"+
		"\u0003\u01d0\u00e8\u0000\u1554\u01c7\u0001\u0000\u0000\u0000\u1555\u1556"+
		"\u0003\u023a\u011d\u0000\u1556\u1557\u0005\u01c0\u0000\u0000\u1557\u1558"+
		"\u0005\u0014\u0000\u0000\u1558\u1559\u0005\u0228\u0000\u0000\u1559\u155a"+
		"\u0005\u0491\u0000\u0000\u155a\u1571\u0001\u0000\u0000\u0000\u155b\u155c"+
		"\u0003\u023a\u011d\u0000\u155c\u155d\u0005\u01c0\u0000\u0000\u155d\u155e"+
		"\u0005\u0014\u0000\u0000\u155e\u1562\u0005\u0491\u0000\u0000\u155f\u1560"+
		"\u0005\u0092\u0000\u0000\u1560\u1561\u0005$\u0000\u0000\u1561\u1563\u0005"+
		"\u0228\u0000\u0000\u1562\u155f\u0001\u0000\u0000\u0000\u1562\u1563\u0001"+
		"\u0000\u0000\u0000\u1563\u1571\u0001\u0000\u0000\u0000\u1564\u1565\u0003"+
		"\u023a\u011d\u0000\u1565\u1566\u0005\u01c0\u0000\u0000\u1566\u1567\u0007"+
		"F\u0000\u0000\u1567\u156c\u0003\u01ca\u00e5\u0000\u1568\u1569\u0005{\u0000"+
		"\u0000\u1569\u156b\u0003\u01ca\u00e5\u0000\u156a\u1568\u0001\u0000\u0000"+
		"\u0000\u156b\u156e\u0001\u0000\u0000\u0000\u156c\u156a\u0001\u0000\u0000"+
		"\u0000\u156c\u156d\u0001\u0000\u0000\u0000\u156d\u1571\u0001\u0000\u0000"+
		"\u0000\u156e\u156c\u0001\u0000\u0000\u0000\u156f\u1571\u0003\u023a\u011d"+
		"\u0000\u1570\u1555\u0001\u0000\u0000\u0000\u1570\u155b\u0001\u0000\u0000"+
		"\u0000\u1570\u1564\u0001\u0000\u0000\u0000\u1570\u156f\u0001\u0000\u0000"+
		"\u0000\u1571\u01c9\u0001\u0000\u0000\u0000\u1572\u1575\u0003\u024e\u0127"+
		"\u0000\u1573\u1574\u0007G\u0000\u0000\u1574\u1576\u0005\u0491\u0000\u0000"+
		"\u1575\u1573\u0001\u0000\u0000\u0000\u1575\u1576\u0001\u0000\u0000\u0000"+
		"\u1576\u157c\u0001\u0000\u0000\u0000\u1577\u1578\u0003\u024e\u0127\u0000"+
		"\u1578\u1579\u0007H\u0000\u0000\u1579\u157a\u0003\u02b4\u015a\u0000\u157a"+
		"\u157c\u0001\u0000\u0000\u0000\u157b\u1572\u0001\u0000\u0000\u0000\u157b"+
		"\u1577\u0001\u0000\u0000\u0000\u157c\u01cb\u0001\u0000\u0000\u0000\u157d"+
		"\u1586\u0005\u00a7\u0000\u0000\u157e\u1586\u0005\u02ae\u0000\u0000\u157f"+
		"\u1580\u0005\u0166\u0000\u0000\u1580\u1586\u0005\u0491\u0000\u0000\u1581"+
		"\u1582\u0005\u01d1\u0000\u0000\u1582\u1586\u0005\u0491\u0000\u0000\u1583"+
		"\u1584\u0005\u0283\u0000\u0000\u1584\u1586\u0005\u0491\u0000\u0000\u1585"+
		"\u157d\u0001\u0000\u0000\u0000\u1585\u157e\u0001\u0000\u0000\u0000\u1585"+
		"\u157f\u0001\u0000\u0000\u0000\u1585\u1581\u0001\u0000\u0000\u0000\u1585"+
		"\u1583\u0001\u0000\u0000\u0000\u1586\u01cd\u0001\u0000\u0000\u0000\u1587"+
		"\u1588\u0005\u01f4\u0000\u0000\u1588\u1590\u0003\u0256\u012b\u0000\u1589"+
		"\u158a\u0005\u01f7\u0000\u0000\u158a\u1590\u0003\u0256\u012b\u0000\u158b"+
		"\u158c\u0005\u01f3\u0000\u0000\u158c\u1590\u0003\u0256\u012b\u0000\u158d"+
		"\u158e\u0005\u01f8\u0000\u0000\u158e\u1590\u0003\u0256\u012b\u0000\u158f"+
		"\u1587\u0001\u0000\u0000\u0000\u158f\u1589\u0001\u0000\u0000\u0000\u158f"+
		"\u158b\u0001\u0000\u0000\u0000\u158f\u158d\u0001\u0000\u0000\u0000\u1590"+
		"\u01cf\u0001\u0000\u0000\u0000\u1591\u1592\u0005\u0228\u0000\u0000\u1592"+
		"\u1599\u0005\u01a4\u0000\u0000\u1593\u159a\u0005+\u0000\u0000\u1594\u159a"+
		"\u0005\u0208\u0000\u0000\u1595\u1596\u0005V\u0000\u0000\u1596\u1597\u0003"+
		"\u0256\u012b\u0000\u1597\u1598\u0005\u02b9\u0000\u0000\u1598\u159a\u0001"+
		"\u0000\u0000\u0000\u1599\u1593\u0001\u0000\u0000\u0000\u1599\u1594\u0001"+
		"\u0000\u0000\u0000\u1599\u1595\u0001\u0000\u0000\u0000\u1599\u159a\u0001"+
		"\u0000\u0000\u0000\u159a\u15b8\u0001\u0000\u0000\u0000\u159b\u159c\u0005"+
		"\u0228\u0000\u0000\u159c\u159f\u0005\u01bd\u0000\u0000\u159d\u15a0\u0005"+
		"+\u0000\u0000\u159e\u15a0\u0003\u0256\u012b\u0000\u159f\u159d\u0001\u0000"+
		"\u0000\u0000\u159f\u159e\u0001\u0000\u0000\u0000\u15a0\u15b8\u0001\u0000"+
		"\u0000\u0000\u15a1\u15a2\u0005\u0228\u0000\u0000\u15a2\u15a3\u0005\u0255"+
		"\u0000\u0000\u15a3\u15a8\u0005V\u0000\u0000\u15a4\u15a9\u0005+\u0000\u0000"+
		"\u15a5\u15a6\u0003\u0256\u012b\u0000\u15a6\u15a7\u0005\u02b9\u0000\u0000"+
		"\u15a7\u15a9\u0001\u0000\u0000\u0000\u15a8\u15a4\u0001\u0000\u0000\u0000"+
		"\u15a8\u15a5\u0001\u0000\u0000\u0000\u15a9\u15b8\u0001\u0000\u0000\u0000"+
		"\u15aa\u15ab\u0005\u0228\u0000\u0000\u15ab\u15ac\u0005\u008f\u0000\u0000"+
		"\u15ac\u15ae\u0005$\u0000\u0000\u15ad\u15af\u0007I\u0000\u0000\u15ae\u15ad"+
		"\u0001\u0000\u0000\u0000\u15ae\u15af\u0001\u0000\u0000\u0000\u15af\u15b8"+
		"\u0001\u0000\u0000\u0000\u15b0\u15b1\u0005\u01a8\u0000\u0000\u15b1\u15b8"+
		"\u0003\u0256\u012b\u0000\u15b2\u15b5\u0005\u0229\u0000\u0000\u15b3\u15b6"+
		"\u0003\u0256\u012b\u0000\u15b4\u15b6\u0005\u0295\u0000\u0000\u15b5\u15b3"+
		"\u0001\u0000\u0000\u0000\u15b5\u15b4\u0001\u0000\u0000\u0000\u15b6\u15b8"+
		"\u0001\u0000\u0000\u0000\u15b7\u1591\u0001\u0000\u0000\u0000\u15b7\u159b"+
		"\u0001\u0000\u0000\u0000\u15b7\u15a1\u0001\u0000\u0000\u0000\u15b7\u15aa"+
		"\u0001\u0000\u0000\u0000\u15b7\u15b0\u0001\u0000\u0000\u0000\u15b7\u15b2"+
		"\u0001\u0000\u0000\u0000\u15b8\u01d1\u0001\u0000\u0000\u0000\u15b9\u15ba"+
		"\u0005\u014c\u0000\u0000\u15ba\u15bb\u0007J\u0000\u0000\u15bb\u01d3\u0001"+
		"\u0000\u0000\u0000\u15bc\u15c1\u0003\u01d6\u00eb\u0000\u15bd\u15be\u0005"+
		"\u0482\u0000\u0000\u15be\u15bf\u0003\u0272\u0139\u0000\u15bf\u15c0\u0005"+
		"\u0483\u0000\u0000\u15c0\u15c2\u0001\u0000\u0000\u0000\u15c1\u15bd\u0001"+
		"\u0000\u0000\u0000\u15c1\u15c2\u0001\u0000\u0000\u0000\u15c2\u01d5\u0001"+
		"\u0000\u0000\u0000\u15c3\u15c5\u0005\u0006\u0000\u0000\u15c4\u15c6\u0005"+
		"\u02dc\u0000\u0000\u15c5\u15c4\u0001\u0000\u0000\u0000\u15c5\u15c6\u0001"+
		"\u0000\u0000\u0000\u15c6\u163c\u0001\u0000\u0000\u0000\u15c7\u15c9\u0005"+
		"\u0007\u0000\u0000\u15c8\u15ca\u0005\u02e4\u0000\u0000\u15c9\u15c8\u0001"+
		"\u0000\u0000\u0000\u15c9\u15ca\u0001\u0000\u0000\u0000\u15ca\u163c\u0001"+
		"\u0000\u0000\u0000\u15cb\u15d3\u0005\"\u0000\u0000\u15cc\u15cd\u0005\u028c"+
		"\u0000\u0000\u15cd\u15d4\u0005\u02ed\u0000\u0000\u15ce\u15d4\u0005\u02e4"+
		"\u0000\u0000\u15cf\u15d4\u0005\u02a3\u0000\u0000\u15d0\u15d4\u0005\u029d"+
		"\u0000\u0000\u15d1\u15d4\u0005\u028a\u0000\u0000\u15d2\u15d4\u0005\u0256"+
		"\u0000\u0000\u15d3\u15cc\u0001\u0000\u0000\u0000\u15d3\u15ce\u0001\u0000"+
		"\u0000\u0000\u15d3\u15cf\u0001\u0000\u0000\u0000\u15d3\u15d0\u0001\u0000"+
		"\u0000\u0000\u15d3\u15d1\u0001\u0000\u0000\u0000\u15d3\u15d2\u0001\u0000"+
		"\u0000\u0000\u15d3\u15d4\u0001\u0000\u0000\u0000\u15d4\u163c\u0001\u0000"+
		"\u0000\u0000\u15d5\u163c\u0005-\u0000\u0000\u15d6\u15d8\u00054\u0000\u0000"+
		"\u15d7\u15d9\u0005\u0256\u0000\u0000\u15d8\u15d7\u0001\u0000\u0000\u0000"+
		"\u15d8\u15d9\u0001\u0000\u0000\u0000\u15d9\u163c\u0001\u0000\u0000\u0000"+
		"\u15da\u163c\u0005\u019f\u0000\u0000\u15db\u163c\u0005\u02cc\u0000\u0000"+
		"\u15dc\u163c\u0005\u02cd\u0000\u0000\u15dd\u15de\u0005H\u0000\u0000\u15de"+
		"\u163c\u0005x\u0000\u0000\u15df\u163c\u0005Q\u0000\u0000\u15e0\u163c\u0005"+
		"U\u0000\u0000\u15e1\u15e2\u0005g\u0000\u0000\u15e2\u163c\u0005\u02ed\u0000"+
		"\u0000\u15e3\u163c\u0005\u02dd\u0000\u0000\u15e4\u163c\u0005\u0237\u0000"+
		"\u0000\u15e5\u163c\u0005\u0089\u0000\u0000\u15e6\u163c\u0005\u02de\u0000"+
		"\u0000\u15e7\u15e8\u0005\u024e\u0000\u0000\u15e8\u15ea\u0007K\u0000\u0000"+
		"\u15e9\u15eb\u0005\u02c3\u0000\u0000\u15ea\u15e9\u0001\u0000\u0000\u0000"+
		"\u15ea\u15eb\u0001\u0000\u0000\u0000\u15eb\u163c\u0001\u0000\u0000\u0000"+
		"\u15ec\u163c\u0005\u0099\u0000\u0000\u15ed\u15ee\u0005\u009c\u0000\u0000"+
		"\u15ee\u163c\u0007L\u0000\u0000\u15ef\u163c\u0005\u02ea\u0000\u0000\u15f0"+
		"\u163c\u0005\u02eb\u0000\u0000\u15f1\u163c\u0005\u00b1\u0000\u0000\u15f2"+
		"\u163c\u0005\u00b8\u0000\u0000\u15f3\u163c\u0005\u00b9\u0000\u0000\u15f4"+
		"\u163c\u0005\u02c4\u0000\u0000\u15f5\u163c\u0005\u02c5\u0000\u0000\u15f6"+
		"\u163c\u0005\u02c6\u0000\u0000\u15f7\u163c\u0005\u02c7\u0000\u0000\u15f8"+
		"\u163c\u0005\u02c8\u0000\u0000\u15f9\u163c\u0005\u02c9\u0000\u0000\u15fa"+
		"\u163c\u0005\u02ca\u0000\u0000\u15fb\u163c\u0005\u02cb\u0000\u0000\u15fc"+
		"\u163c\u0005\u02ce\u0000\u0000\u15fd\u163c\u0005\u02cf\u0000\u0000\u15fe"+
		"\u163c\u0005\u02d0\u0000\u0000\u15ff\u163c\u0005\u02d1\u0000\u0000\u1600"+
		"\u163c\u0005\u02d2\u0000\u0000\u1601\u163c\u0005\u02d3\u0000\u0000\u1602"+
		"\u163c\u0005\u02d4\u0000\u0000\u1603\u163c\u0005\u02d5\u0000\u0000\u1604"+
		"\u163c\u0005\u02d6\u0000\u0000\u1605\u163c\u0005\u02d9\u0000\u0000\u1606"+
		"\u163c\u0005\u02da\u0000\u0000\u1607\u163c\u0005\u02db\u0000\u0000\u1608"+
		"\u163c\u0005\u02df\u0000\u0000\u1609\u163c\u0005\u02e0\u0000\u0000\u160a"+
		"\u163c\u0005\u02e1\u0000\u0000\u160b\u163c\u0005\u02e2\u0000\u0000\u160c"+
		"\u163c\u0005\u02e3\u0000\u0000\u160d\u163c\u0005\u02e6\u0000\u0000\u160e"+
		"\u163c\u0005\u02e7\u0000\u0000\u160f\u163c\u0005\u02e8\u0000\u0000\u1610"+
		"\u163c\u0005\u02e9\u0000\u0000\u1611\u163c\u0005\u043b\u0000\u0000\u1612"+
		"\u163c\u0005\u02ec\u0000\u0000\u1613\u163c\u0005\u02ee\u0000\u0000\u1614"+
		"\u163c\u0005\u02ef\u0000\u0000\u1615\u163c\u0005\u02f0\u0000\u0000\u1616"+
		"\u163c\u0005\u045f\u0000\u0000\u1617\u163c\u0005\u0460\u0000\u0000\u1618"+
		"\u163c\u0005\u0461\u0000\u0000\u1619\u163c\u0005\u0462\u0000\u0000\u161a"+
		"\u163c\u0005\u0465\u0000\u0000\u161b\u161c\u0005\u0159\u0000\u0000\u161c"+
		"\u163c\u0007M\u0000\u0000\u161d\u161e\u0005\u031d\u0000\u0000\u161e\u163c"+
		"\u0005\u02c3\u0000\u0000\u161f\u1620\u0005\u0087\u0000\u0000\u1620\u1623"+
		"\u0005\u021b\u0000\u0000\u1621\u1623\u0005\u0467\u0000\u0000\u1622\u161f"+
		"\u0001\u0000\u0000\u0000\u1622\u1621\u0001\u0000\u0000\u0000\u1623\u1624"+
		"\u0001\u0000\u0000\u0000\u1624\u163c\u0005\u02c3\u0000\u0000\u1625\u1626"+
		"\u0005\u02c3\u0000\u0000\u1626\u163c\u0005x\u0000\u0000\u1627\u1628\u0005"+
		"\u0178\u0000\u0000\u1628\u163c\u0005\u02c3\u0000\u0000\u1629\u162a\u0005"+
		"-\u0000\u0000\u162a\u163c\u0005\u01bd\u0000\u0000\u162b\u162c\u0005\u0463"+
		"\u0000\u0000\u162c\u163c\u0005\u0466\u0000\u0000\u162d\u162e\u0005H\u0000"+
		"\u0000\u162e\u163c\u0005x\u0000\u0000\u162f\u1630\u0005\u009a\u0000\u0000"+
		"\u1630\u163c\u0005\u029d\u0000\u0000\u1631\u1632\u0005\u0268\u0000\u0000"+
		"\u1632\u163c\u0005\u0466\u0000\u0000\u1633\u1634\u0005f\u0000\u0000\u1634"+
		"\u1635\u0005D\u0000\u0000\u1635\u163c\u0005\u02e5\u0000\u0000\u1636\u1637"+
		"\u0005\u0099\u0000\u0000\u1637\u1638\u0005W\u0000\u0000\u1638\u163c\u0005"+
		"\u02e5\u0000\u0000\u1639\u163a\u0005\u02d7\u0000\u0000\u163a\u163c\u0005"+
		"\u02d8\u0000\u0000\u163b\u15c3\u0001\u0000\u0000\u0000\u163b\u15c7\u0001"+
		"\u0000\u0000\u0000\u163b\u15cb\u0001\u0000\u0000\u0000\u163b\u15d5\u0001"+
		"\u0000\u0000\u0000\u163b\u15d6\u0001\u0000\u0000\u0000\u163b\u15da\u0001"+
		"\u0000\u0000\u0000\u163b\u15db\u0001\u0000\u0000\u0000\u163b\u15dc\u0001"+
		"\u0000\u0000\u0000\u163b\u15dd\u0001\u0000\u0000\u0000\u163b\u15df\u0001"+
		"\u0000\u0000\u0000\u163b\u15e0\u0001\u0000\u0000\u0000\u163b\u15e1\u0001"+
		"\u0000\u0000\u0000\u163b\u15e3\u0001\u0000\u0000\u0000\u163b\u15e4\u0001"+
		"\u0000\u0000\u0000\u163b\u15e5\u0001\u0000\u0000\u0000\u163b\u15e6\u0001"+
		"\u0000\u0000\u0000\u163b\u15e7\u0001\u0000\u0000\u0000\u163b\u15ec\u0001"+
		"\u0000\u0000\u0000\u163b\u15ed\u0001\u0000\u0000\u0000\u163b\u15ef\u0001"+
		"\u0000\u0000\u0000\u163b\u15f0\u0001\u0000\u0000\u0000\u163b\u15f1\u0001"+
		"\u0000\u0000\u0000\u163b\u15f2\u0001\u0000\u0000\u0000\u163b\u15f3\u0001"+
		"\u0000\u0000\u0000\u163b\u15f4\u0001\u0000\u0000\u0000\u163b\u15f5\u0001"+
		"\u0000\u0000\u0000\u163b\u15f6\u0001\u0000\u0000\u0000\u163b\u15f7\u0001"+
		"\u0000\u0000\u0000\u163b\u15f8\u0001\u0000\u0000\u0000\u163b\u15f9\u0001"+
		"\u0000\u0000\u0000\u163b\u15fa\u0001\u0000\u0000\u0000\u163b\u15fb\u0001"+
		"\u0000\u0000\u0000\u163b\u15fc\u0001\u0000\u0000\u0000\u163b\u15fd\u0001"+
		"\u0000\u0000\u0000\u163b\u15fe\u0001\u0000\u0000\u0000\u163b\u15ff\u0001"+
		"\u0000\u0000\u0000\u163b\u1600\u0001\u0000\u0000\u0000\u163b\u1601\u0001"+
		"\u0000\u0000\u0000\u163b\u1602\u0001\u0000\u0000\u0000\u163b\u1603\u0001"+
		"\u0000\u0000\u0000\u163b\u1604\u0001\u0000\u0000\u0000\u163b\u1605\u0001"+
		"\u0000\u0000\u0000\u163b\u1606\u0001\u0000\u0000\u0000\u163b\u1607\u0001"+
		"\u0000\u0000\u0000\u163b\u1608\u0001\u0000\u0000\u0000\u163b\u1609\u0001"+
		"\u0000\u0000\u0000\u163b\u160a\u0001\u0000\u0000\u0000\u163b\u160b\u0001"+
		"\u0000\u0000\u0000\u163b\u160c\u0001\u0000\u0000\u0000\u163b\u160d\u0001"+
		"\u0000\u0000\u0000\u163b\u160e\u0001\u0000\u0000\u0000\u163b\u160f\u0001"+
		"\u0000\u0000\u0000\u163b\u1610\u0001\u0000\u0000\u0000\u163b\u1611\u0001"+
		"\u0000\u0000\u0000\u163b\u1612\u0001\u0000\u0000\u0000\u163b\u1613\u0001"+
		"\u0000\u0000\u0000\u163b\u1614\u0001\u0000\u0000\u0000\u163b\u1615\u0001"+
		"\u0000\u0000\u0000\u163b\u1616\u0001\u0000\u0000\u0000\u163b\u1617\u0001"+
		"\u0000\u0000\u0000\u163b\u1618\u0001\u0000\u0000\u0000\u163b\u1619\u0001"+
		"\u0000\u0000\u0000\u163b\u161a\u0001\u0000\u0000\u0000\u163b\u161b\u0001"+
		"\u0000\u0000\u0000\u163b\u161d\u0001\u0000\u0000\u0000\u163b\u1622\u0001"+
		"\u0000\u0000\u0000\u163b\u1625\u0001\u0000\u0000\u0000\u163b\u1627\u0001"+
		"\u0000\u0000\u0000\u163b\u1629\u0001\u0000\u0000\u0000\u163b\u162b\u0001"+
		"\u0000\u0000\u0000\u163b\u162d\u0001\u0000\u0000\u0000\u163b\u162f\u0001"+
		"\u0000\u0000\u0000\u163b\u1631\u0001\u0000\u0000\u0000\u163b\u1633\u0001"+
		"\u0000\u0000\u0000\u163b\u1636\u0001\u0000\u0000\u0000\u163b\u1639\u0001"+
		"\u0000\u0000\u0000\u163c\u01d7\u0001\u0000\u0000\u0000\u163d\u164e\u0005"+
		"\u0472\u0000\u0000\u163e\u163f\u0005\u0472\u0000\u0000\u163f\u1640\u0005"+
		"\u0481\u0000\u0000\u1640\u164e\u0005\u0472\u0000\u0000\u1641\u1642\u0003"+
		"\u0250\u0128\u0000\u1642\u1643\u0005\u0481\u0000\u0000\u1643\u1644\u0005"+
		"\u0472\u0000\u0000\u1644\u164e\u0001\u0000\u0000\u0000\u1645\u1646\u0003"+
		"\u0250\u0128\u0000\u1646\u1647\u0005\u0481\u0000\u0000\u1647\u1648\u0003"+
		"\u0250\u0128\u0000\u1648\u164e\u0001\u0000\u0000\u0000\u1649\u164a\u0003"+
		"\u0250\u0128\u0000\u164a\u164b\u0003\u0254\u012a\u0000\u164b\u164e\u0001"+
		"\u0000\u0000\u0000\u164c\u164e\u0003\u0250\u0128\u0000\u164d\u163d\u0001"+
		"\u0000\u0000\u0000\u164d\u163e\u0001\u0000\u0000\u0000\u164d\u1641\u0001"+
		"\u0000\u0000\u0000\u164d\u1645\u0001\u0000\u0000\u0000\u164d\u1649\u0001"+
		"\u0000\u0000\u0000\u164d\u164c\u0001\u0000\u0000\u0000\u164e\u01d9\u0001"+
		"\u0000\u0000\u0000\u164f\u1650\u0003\u023a\u011d\u0000\u1650\u1651\u0005"+
		"\u00af\u0000\u0000\u1651\u1652\u0003\u023a\u011d\u0000\u1652\u01db\u0001"+
		"\u0000\u0000\u0000\u1653\u1655\u0005\t\u0000\u0000\u1654\u1656\u0007N"+
		"\u0000\u0000\u1655\u1654\u0001\u0000\u0000\u0000\u1655\u1656\u0001\u0000"+
		"\u0000\u0000\u1656\u1657\u0001\u0000\u0000\u0000\u1657\u1658\u00079\u0000"+
		"\u0000\u1658\u166a\u0003\u0274\u013a\u0000\u1659\u165a\u0005\u00b8\u0000"+
		"\u0000\u165a\u165b\u0005L\u0000\u0000\u165b\u165c\u0005v\u0000\u0000\u165c"+
		"\u1661\u0003\u0232\u0119\u0000\u165d\u165e\u0005\u0484\u0000\u0000\u165e"+
		"\u1660\u0003\u0232\u0119\u0000\u165f\u165d\u0001\u0000\u0000\u0000\u1660"+
		"\u1663\u0001\u0000\u0000\u0000\u1661\u165f\u0001\u0000\u0000\u0000\u1661"+
		"\u1662\u0001\u0000\u0000\u0000\u1662\u1668\u0001\u0000\u0000\u0000\u1663"+
		"\u1661\u0001\u0000\u0000\u0000\u1664\u1665\u0005\u00c0\u0000\u0000\u1665"+
		"\u1666\u0003\u0256\u012b\u0000\u1666\u1667\u0005\u0013\u0000\u0000\u1667"+
		"\u1669\u0001\u0000\u0000\u0000\u1668\u1664\u0001\u0000\u0000\u0000\u1668"+
		"\u1669\u0001\u0000\u0000\u0000\u1669\u166b\u0001\u0000\u0000\u0000\u166a"+
		"\u1659\u0001\u0000\u0000\u0000\u166a\u166b\u0001\u0000\u0000\u0000\u166b"+
		"\u1677\u0001\u0000\u0000\u0000\u166c\u166d\u00054\u0000\u0000\u166d\u166e"+
		"\u0005L\u0000\u0000\u166e\u166f\u0005v\u0000\u0000\u166f\u1674\u0003\u0232"+
		"\u0119\u0000\u1670\u1671\u0005\u0484\u0000\u0000\u1671\u1673\u0003\u0232"+
		"\u0119\u0000\u1672\u1670\u0001\u0000\u0000\u0000\u1673\u1676\u0001\u0000"+
		"\u0000\u0000\u1674\u1672\u0001\u0000\u0000\u0000\u1674\u1675\u0001\u0000"+
		"\u0000\u0000\u1675\u1678\u0001\u0000\u0000\u0000\u1676\u1674\u0001\u0000"+
		"\u0000\u0000\u1677\u166c\u0001\u0000\u0000\u0000\u1677\u1678\u0001\u0000"+
		"\u0000\u0000\u1678\u01dd\u0001\u0000\u0000\u0000\u1679\u167a\u0005\u001b"+
		"\u0000\u0000\u167a\u167b\u0005\u00ac\u0000\u0000\u167b\u167f\u0003\u0274"+
		"\u013a\u0000\u167c\u167e\u0003\u01e6\u00f3\u0000\u167d\u167c\u0001\u0000"+
		"\u0000\u0000\u167e\u1681\u0001\u0000\u0000\u0000\u167f\u167d\u0001\u0000"+
		"\u0000\u0000\u167f\u1680\u0001\u0000\u0000\u0000\u1680\u01df\u0001\u0000"+
		"\u0000\u0000\u1681\u167f\u0001\u0000\u0000\u0000\u1682\u1683\u0005\u0164"+
		"\u0000\u0000\u1683\u1684\u0005\u00ac\u0000\u0000\u1684\u1686\u0003\u0274"+
		"\u013a\u0000\u1685\u1687\u0007O\u0000\u0000\u1686\u1685\u0001\u0000\u0000"+
		"\u0000\u1686\u1687\u0001\u0000\u0000\u0000\u1687\u01e1\u0001\u0000\u0000"+
		"\u0000\u1688\u168a\u0005w\u0000\u0000\u1689\u168b\u0007N\u0000\u0000\u168a"+
		"\u1689\u0001\u0000\u0000\u0000\u168a\u168b\u0001\u0000\u0000\u0000\u168b"+
		"\u168c\u0001\u0000\u0000\u0000\u168c\u168d\u00079\u0000\u0000\u168d\u168f"+
		"\u0003\u0274\u013a\u0000\u168e\u1690\u0003\u028e\u0147\u0000\u168f\u168e"+
		"\u0001\u0000\u0000\u0000\u168f\u1690\u0001\u0000\u0000\u0000\u1690\u01e3"+
		"\u0001\u0000\u0000\u0000\u1691\u1693\u0005\u0246\u0000\u0000\u1692\u1694"+
		"\u0007N\u0000\u0000\u1693\u1692\u0001\u0000\u0000\u0000\u1693\u1694\u0001"+
		"\u0000\u0000\u0000\u1694\u1695\u0001\u0000\u0000\u0000\u1695\u1696\u0005"+
		"\u00ac\u0000\u0000\u1696\u1698\u0003\u0274\u013a\u0000\u1697\u1699\u0005"+
		"\u023a\u0000\u0000\u1698\u1697\u0001\u0000\u0000\u0000\u1698\u1699\u0001"+
		"\u0000\u0000\u0000\u1699\u169b\u0001\u0000\u0000\u0000\u169a\u169c\u0005"+
		"\u01a6\u0000\u0000\u169b\u169a\u0001\u0000\u0000\u0000\u169b\u169c\u0001"+
		"\u0000\u0000\u0000\u169c\u169e\u0001\u0000\u0000\u0000\u169d\u169f\u0005"+
		"\u029e\u0000\u0000\u169e\u169d\u0001\u0000\u0000\u0000\u169e\u169f\u0001"+
		"\u0000\u0000\u0000\u169f\u01e5\u0001\u0000\u0000\u0000\u16a0\u16a1\u0005"+
		"A\u0000\u0000\u16a1\u16a8\u0005\u029c\u0000\u0000\u16a2\u16a8\u0005\u023a"+
		"\u0000\u0000\u16a3\u16a8\u0005\u01a9\u0000\u0000\u16a4\u16a8\u0005\u01f9"+
		"\u0000\u0000\u16a5\u16a8\u0005\u01a6\u0000\u0000\u16a6\u16a8\u0005\u0162"+
		"\u0000\u0000\u16a7\u16a0\u0001\u0000\u0000\u0000\u16a7\u16a2\u0001\u0000"+
		"\u0000\u0000\u16a7\u16a3\u0001\u0000\u0000\u0000\u16a7\u16a4\u0001\u0000"+
		"\u0000\u0000\u16a7\u16a5\u0001\u0000\u0000\u0000\u16a7\u16a6\u0001\u0000"+
		"\u0000\u0000\u16a8\u01e7\u0001\u0000\u0000\u0000\u16a9\u16ab\u0005\"\u0000"+
		"\u0000\u16aa\u16ac\u0003\u028c\u0146\u0000\u16ab\u16aa\u0001\u0000\u0000"+
		"\u0000\u16ab\u16ac\u0001\u0000\u0000\u0000\u16ac\u16ae\u0001\u0000\u0000"+
		"\u0000\u16ad\u16af\u0005\u014f\u0000\u0000\u16ae\u16ad\u0001\u0000\u0000"+
		"\u0000\u16ae\u16af\u0001\u0000\u0000\u0000\u16af\u16b0\u0001\u0000\u0000"+
		"\u0000\u16b0\u16b2\u0005\u01b5\u0000\u0000\u16b1\u16b3\u0003\u028a\u0145"+
		"\u0000\u16b2\u16b1\u0001\u0000\u0000\u0000\u16b2\u16b3\u0001\u0000\u0000"+
		"\u0000\u16b3\u16b4\u0001\u0000\u0000\u0000\u16b4\u16b5\u0003\u0250\u0128"+
		"\u0000\u16b5\u16b6\u0005\u0254\u0000\u0000\u16b6\u16b7\u0007P\u0000\u0000"+
		"\u16b7\u16b8\u0005\u026e\u0000\u0000\u16b8\u16b9\u0005\u0491\u0000\u0000"+
		"\u16b9\u01e9\u0001\u0000\u0000\u0000\u16ba\u16bb\u0005\u01c8\u0000\u0000"+
		"\u16bb\u16bc\u0005\u022b\u0000\u0000\u16bc\u16bd\u0003\u0250\u0128\u0000"+
		"\u16bd\u16be\u0005\u026e\u0000\u0000\u16be\u16bf\u0005\u0491\u0000\u0000"+
		"\u16bf\u01eb\u0001\u0000\u0000\u0000\u16c0\u16c1\u0005\u0299\u0000\u0000"+
		"\u16c1\u16c2\u0005\u022b\u0000\u0000\u16c2\u16c3\u0003\u0250\u0128\u0000"+
		"\u16c3\u01ed\u0001\u0000\u0000\u0000\u16c4\u16c5\u0005\u009a\u0000\u0000"+
		"\u16c5\u16c6\u0003\u01f4\u00fa\u0000\u16c6\u16c9\u0007Q\u0000\u0000\u16c7"+
		"\u16ca\u0003\u02ba\u015d\u0000\u16c8\u16ca\u0005v\u0000\u0000\u16c9\u16c7"+
		"\u0001\u0000\u0000\u0000\u16c9\u16c8\u0001\u0000\u0000\u0000\u16ca\u16d4"+
		"\u0001\u0000\u0000\u0000\u16cb\u16cc\u0005\u0484\u0000\u0000\u16cc\u16cd"+
		"\u0003\u01f4\u00fa\u0000\u16cd\u16d0\u0007Q\u0000\u0000\u16ce\u16d1\u0003"+
		"\u02ba\u015d\u0000\u16cf\u16d1\u0005v\u0000\u0000\u16d0\u16ce\u0001\u0000"+
		"\u0000\u0000\u16d0\u16cf\u0001\u0000\u0000\u0000\u16d1\u16d3\u0001\u0000"+
		"\u0000\u0000\u16d2\u16cb\u0001\u0000\u0000\u0000\u16d3\u16d6\u0001\u0000"+
		"\u0000\u0000\u16d4\u16d2\u0001\u0000\u0000\u0000\u16d4\u16d5\u0001\u0000"+
		"\u0000\u0000\u16d5\u16f9\u0001\u0000\u0000\u0000\u16d6\u16d4\u0001\u0000"+
		"\u0000\u0000\u16d7\u16d8\u0005\u009a\u0000\u0000\u16d8\u16db\u0003B!\u0000"+
		"\u16d9\u16dc\u0003\u023e\u011f\u0000\u16da\u16dc\u0005+\u0000\u0000\u16db"+
		"\u16d9\u0001\u0000\u0000\u0000\u16db\u16da\u0001\u0000\u0000\u0000\u16dc"+
		"\u16f9\u0001\u0000\u0000\u0000\u16dd\u16de\u0005\u009a\u0000\u0000\u16de"+
		"\u16e5\u0005\u0206\u0000\u0000\u16df\u16e2\u0003\u023e\u011f\u0000\u16e0"+
		"\u16e1\u0005\u001c\u0000\u0000\u16e1\u16e3\u0003\u0240\u0120\u0000\u16e2"+
		"\u16e0\u0001\u0000\u0000\u0000\u16e2\u16e3\u0001\u0000\u0000\u0000\u16e3"+
		"\u16e6\u0001\u0000\u0000\u0000\u16e4\u16e6\u0005+\u0000\u0000\u16e5\u16df"+
		"\u0001\u0000\u0000\u0000\u16e5\u16e4\u0001\u0000\u0000\u0000\u16e6\u16f9"+
		"\u0001\u0000\u0000\u0000\u16e7\u16f9\u0003\u01c4\u00e2\u0000\u16e8\u16f9"+
		"\u0003\u0146\u00a3\u0000\u16e9\u16f9\u0003\u0144\u00a2\u0000\u16ea\u16eb"+
		"\u0005\u009a\u0000\u0000\u16eb\u16ec\u0003\u022c\u0116\u0000\u16ec\u16ed"+
		"\u0007Q\u0000\u0000\u16ed\u16f5\u0003\u02ba\u015d\u0000\u16ee\u16ef\u0005"+
		"\u0484\u0000\u0000\u16ef\u16f0\u0003\u022c\u0116\u0000\u16f0\u16f1\u0007"+
		"Q\u0000\u0000\u16f1\u16f2\u0003\u02ba\u015d\u0000\u16f2\u16f4\u0001\u0000"+
		"\u0000\u0000\u16f3\u16ee\u0001\u0000\u0000\u0000\u16f4\u16f7\u0001\u0000"+
		"\u0000\u0000\u16f5\u16f3\u0001\u0000\u0000\u0000\u16f5\u16f6\u0001\u0000"+
		"\u0000\u0000\u16f6\u16f9\u0001\u0000\u0000\u0000\u16f7\u16f5\u0001\u0000"+
		"\u0000\u0000\u16f8\u16c4\u0001\u0000\u0000\u0000\u16f8\u16d7\u0001\u0000"+
		"\u0000\u0000\u16f8\u16dd\u0001\u0000\u0000\u0000\u16f8\u16e7\u0001\u0000"+
		"\u0000\u0000\u16f8\u16e8\u0001\u0000\u0000\u0000\u16f8\u16e9\u0001\u0000"+
		"\u0000\u0000\u16f8\u16ea\u0001\u0000\u0000\u0000\u16f9\u01ef\u0001\u0000"+
		"\u0000\u0000\u16fa\u16fb\u0005\u009c\u0000\u0000\u16fb\u16fc\u0007;\u0000"+
		"\u0000\u16fc\u17ba\u0005\u01dd\u0000\u0000\u16fd\u16fe\u0005\u009c\u0000"+
		"\u0000\u16fe\u16ff\u0005\u0159\u0000\u0000\u16ff\u1702\u0005\u01a0\u0000"+
		"\u0000\u1700\u1701\u0005P\u0000\u0000\u1701\u1703\u0005\u0491\u0000\u0000"+
		"\u1702\u1700\u0001\u0000\u0000\u0000\u1702\u1703\u0001\u0000\u0000\u0000"+
		"\u1703\u1706\u0001\u0000\u0000\u0000\u1704\u1705\u0005D\u0000\u0000\u1705"+
		"\u1707\u0003\u0256\u012b\u0000\u1706\u1704\u0001\u0000\u0000\u0000\u1706"+
		"\u1707\u0001\u0000\u0000\u0000\u1707\u1709\u0001\u0000\u0000\u0000\u1708"+
		"\u170a\u0003\u012e\u0097\u0000\u1709\u1708\u0001\u0000\u0000\u0000\u1709"+
		"\u170a\u0001\u0000\u0000\u0000\u170a\u17ba\u0001\u0000\u0000\u0000\u170b"+
		"\u170c\u0005\u009c\u0000\u0000\u170c\u170e\u0005\u0243\u0000\u0000\u170d"+
		"\u170f\u0005\u0491\u0000\u0000\u170e\u170d\u0001\u0000\u0000\u0000\u170e"+
		"\u170f\u0001\u0000\u0000\u0000\u170f\u1710\u0001\u0000\u0000\u0000\u1710"+
		"\u1713\u0005\u01a0\u0000\u0000\u1711\u1712\u0005P\u0000\u0000\u1712\u1714"+
		"\u0005\u0491\u0000\u0000\u1713\u1711\u0001\u0000\u0000\u0000\u1713\u1714"+
		"\u0001\u0000\u0000\u0000\u1714\u1717\u0001\u0000\u0000\u0000\u1715\u1716"+
		"\u0005D\u0000\u0000\u1716\u1718\u0003\u0256\u012b\u0000\u1717\u1715\u0001"+
		"\u0000\u0000\u0000\u1717\u1718\u0001\u0000\u0000\u0000\u1718\u171a\u0001"+
		"\u0000\u0000\u0000\u1719\u171b\u0003\u012e\u0097\u0000\u171a\u1719\u0001"+
		"\u0000\u0000\u0000\u171a\u171b\u0001\u0000\u0000\u0000\u171b\u171f\u0001"+
		"\u0000\u0000\u0000\u171c\u171d\u0005A\u0000\u0000\u171d\u171e\u0005\u0163"+
		"\u0000\u0000\u171e\u1720\u0005\u0491\u0000\u0000\u171f\u171c\u0001\u0000"+
		"\u0000\u0000\u171f\u1720\u0001\u0000\u0000\u0000\u1720\u17ba\u0001\u0000"+
		"\u0000\u0000\u1721\u1722\u0005\u009c\u0000\u0000\u1722\u1724\u0003\u01f6"+
		"\u00fb\u0000\u1723\u1725\u0003\u01f8\u00fc\u0000\u1724\u1723\u0001\u0000"+
		"\u0000\u0000\u1724\u1725\u0001\u0000\u0000\u0000\u1725\u17ba\u0001\u0000"+
		"\u0000\u0000\u1726\u1728\u0005\u009c\u0000\u0000\u1727\u1729\u0005\u01b4"+
		"\u0000\u0000\u1728\u1727\u0001\u0000\u0000\u0000\u1728\u1729\u0001\u0000"+
		"\u0000\u0000\u1729\u172a\u0001\u0000\u0000\u0000\u172a\u172b\u0007,\u0000"+
		"\u0000\u172b\u172c\u0007R\u0000\u0000\u172c\u172f\u0003\u022e\u0117\u0000"+
		"\u172d\u172e\u0007R\u0000\u0000\u172e\u1730\u0003\u0250\u0128\u0000\u172f"+
		"\u172d\u0001\u0000\u0000\u0000\u172f\u1730\u0001\u0000\u0000\u0000\u1730"+
		"\u1732\u0001\u0000\u0000\u0000\u1731\u1733\u0003\u01f8\u00fc\u0000\u1732"+
		"\u1731\u0001\u0000\u0000\u0000\u1732\u1733\u0001\u0000\u0000\u0000\u1733"+
		"\u17ba\u0001\u0000\u0000\u0000\u1734\u1735\u0005\u009c\u0000\u0000\u1735"+
		"\u1736\u0005\"\u0000\u0000\u1736\u1738\u0007\u0000\u0000\u0000\u1737\u1739"+
		"\u0003\u028a\u0145\u0000\u1738\u1737\u0001\u0000\u0000\u0000\u1738\u1739"+
		"\u0001\u0000\u0000\u0000\u1739\u173a\u0001\u0000\u0000\u0000\u173a\u17ba"+
		"\u0003\u0250\u0128\u0000\u173b\u173c\u0005\u009c\u0000\u0000\u173c\u173d"+
		"\u0005\"\u0000\u0000\u173d\u173e\u0007S\u0000\u0000\u173e\u17ba\u0003"+
		"\u022c\u0116\u0000\u173f\u1740\u0005\u009c\u0000\u0000\u1740\u1741\u0005"+
		"\"\u0000\u0000\u1741\u1743\u0005\u0083\u0000\u0000\u1742\u1744\u0005\u0011"+
		"\u0000\u0000\u1743\u1742\u0001\u0000\u0000\u0000\u1743\u1744\u0001\u0000"+
		"\u0000\u0000\u1744\u1745\u0001\u0000\u0000\u0000\u1745\u17ba\u0003\u022c"+
		"\u0116\u0000\u1746\u1747\u0005\u009c\u0000\u0000\u1747\u1748\u0005\"\u0000"+
		"\u0000\u1748\u1749\u0005\u029d\u0000\u0000\u1749\u17ba\u0003\u023a\u011d"+
		"\u0000\u174a\u174b\u0005\u009c\u0000\u0000\u174b\u174c\u0005\u0199\u0000"+
		"\u0000\u174c\u174d\u0003\u0242\u0121\u0000\u174d\u174e\u0007T\u0000\u0000"+
		"\u174e\u17ba\u0001\u0000\u0000\u0000\u174f\u1750\u0005\u009c\u0000\u0000"+
		"\u1750\u1751\u0005\u031e\u0000\u0000\u1751\u17ba\u0005\u027d\u0000\u0000"+
		"\u1752\u1753\u0005\u009c\u0000\u0000\u1753\u17ba\u0003\u01fa\u00fd\u0000"+
		"\u1754\u1755\u0005\u009c\u0000\u0000\u1755\u1757\u0007U\u0000\u0000\u1756"+
		"\u1758\u0003\u012e\u0097\u0000\u1757\u1756\u0001\u0000\u0000\u0000\u1757"+
		"\u1758\u0001\u0000\u0000\u0000\u1758\u17ba\u0001\u0000\u0000\u0000\u1759"+
		"\u175a\u0005\u009c\u0000\u0000\u175a\u175b\u0005\u0122\u0000\u0000\u175b"+
		"\u175c\u0005\u0482\u0000\u0000\u175c\u175d\u0005\u0472\u0000\u0000\u175d"+
		"\u175e\u0005\u0483\u0000\u0000\u175e\u17ba\u0007U\u0000\u0000\u175f\u1760"+
		"\u0005\u009c\u0000\u0000\u1760\u1763\u0003\u01fc\u00fe\u0000\u1761\u1762"+
		"\u0007R\u0000\u0000\u1762\u1764\u0003\u0250\u0128\u0000\u1763\u1761\u0001"+
		"\u0000\u0000\u0000\u1763\u1764\u0001\u0000\u0000\u0000\u1764\u1766\u0001"+
		"\u0000\u0000\u0000\u1765\u1767\u0003\u01f8\u00fc\u0000\u1766\u1765\u0001"+
		"\u0000\u0000\u0000\u1766\u1767\u0001\u0000\u0000\u0000\u1767\u17ba\u0001"+
		"\u0000\u0000\u0000\u1768\u1769\u0005\u009c\u0000\u0000\u1769\u176a\u0007"+
		"V\u0000\u0000\u176a\u176b\u0005\u016c\u0000\u0000\u176b\u17ba\u0003\u022c"+
		"\u0116\u0000\u176c\u176d\u0005\u009c\u0000\u0000\u176d\u1770\u0005\u01b8"+
		"\u0000\u0000\u176e\u176f\u0005A\u0000\u0000\u176f\u1771\u0003\u023a\u011d"+
		"\u0000\u1770\u176e\u0001\u0000\u0000\u0000\u1770\u1771\u0001\u0000\u0000"+
		"\u0000\u1771\u17ba\u0001\u0000\u0000\u0000\u1772\u1773\u0005\u009c\u0000"+
		"\u0000\u1773\u1774\u0007W\u0000\u0000\u1774\u1775\u0007R\u0000\u0000\u1775"+
		"\u1778\u0003\u022e\u0117\u0000\u1776\u1777\u0007R\u0000\u0000\u1777\u1779"+
		"\u0003\u0250\u0128\u0000\u1778\u1776\u0001\u0000\u0000\u0000\u1778\u1779"+
		"\u0001\u0000\u0000\u0000\u1779\u177c\u0001\u0000\u0000\u0000\u177a\u177b"+
		"\u0005\u00be\u0000\u0000\u177b\u177d\u0003\u02ba\u015d\u0000\u177c\u177a"+
		"\u0001\u0000\u0000\u0000\u177c\u177d\u0001\u0000\u0000\u0000\u177d\u17ba"+
		"\u0001\u0000\u0000\u0000\u177e\u177f\u0005\u009c\u0000\u0000\u177f\u1780"+
		"\u0005\u021c\u0000\u0000\u1780\u1783\u0005\u02ed\u0000\u0000\u1781\u1782"+
		"\u0007R\u0000\u0000\u1782\u1784\u0003\u022c\u0116\u0000\u1783\u1781\u0001"+
		"\u0000\u0000\u0000\u1783\u1784\u0001\u0000\u0000\u0000\u1784\u1786\u0001"+
		"\u0000\u0000\u0000\u1785\u1787\u0003\u01f8\u00fc\u0000\u1786\u1785\u0001"+
		"\u0000\u0000\u0000\u1786\u1787\u0001\u0000\u0000\u0000\u1787\u17ba\u0001"+
		"\u0000\u0000\u0000\u1788\u1789\u0005\u009c\u0000\u0000\u1789\u1792\u0005"+
		"\u0235\u0000\u0000\u178a\u178f\u0003\u01fe\u00ff\u0000\u178b\u178c\u0005"+
		"\u0484\u0000\u0000\u178c\u178e\u0003\u01fe\u00ff\u0000\u178d\u178b\u0001"+
		"\u0000\u0000\u0000\u178e\u1791\u0001\u0000\u0000\u0000\u178f\u178d\u0001"+
		"\u0000\u0000\u0000\u178f\u1790\u0001\u0000\u0000\u0000\u1790\u1793\u0001"+
		"\u0000\u0000\u0000\u1791\u178f\u0001\u0000\u0000\u0000\u1792\u178a\u0001"+
		"\u0000\u0000\u0000\u1792\u1793\u0001\u0000\u0000\u0000\u1793\u1797\u0001"+
		"\u0000\u0000\u0000\u1794\u1795\u0005A\u0000\u0000\u1795\u1796\u0005\u0238"+
		"\u0000\u0000\u1796\u1798\u0003\u0256\u012b\u0000\u1797\u1794\u0001\u0000"+
		"\u0000\u0000\u1797\u1798\u0001\u0000\u0000\u0000\u1798\u179a\u0001\u0000"+
		"\u0000\u0000\u1799\u179b\u0003\u012e\u0097\u0000\u179a\u1799\u0001\u0000"+
		"\u0000\u0000\u179a\u179b\u0001\u0000\u0000\u0000\u179b\u17ba\u0001\u0000"+
		"\u0000\u0000\u179c\u179d\u0005\u009c\u0000\u0000\u179d\u179f\u0007X\u0000"+
		"\u0000\u179e\u17a0\u0005\u0491\u0000\u0000\u179f\u179e\u0001\u0000\u0000"+
		"\u0000\u179f\u17a0\u0001\u0000\u0000\u0000\u17a0\u17a1\u0001\u0000\u0000"+
		"\u0000\u17a1\u17a5\u0005\u027d\u0000\u0000\u17a2\u17a3\u0005A\u0000\u0000"+
		"\u17a3\u17a4\u0005\u0163\u0000\u0000\u17a4\u17a6\u0005\u0491\u0000\u0000"+
		"\u17a5\u17a2\u0001\u0000\u0000\u0000\u17a5\u17a6\u0001\u0000\u0000\u0000"+
		"\u17a6\u17ba\u0001\u0000\u0000\u0000\u17a7\u17a8\u0005\u009c\u0000\u0000"+
		"\u17a8\u17ba\u0007Y\u0000\u0000\u17a9\u17aa\u0005\u009c\u0000\u0000\u17aa"+
		"\u17ac\u0005>\u0000\u0000\u17ab\u17ad\u0003\u021a\u010d\u0000\u17ac\u17ab"+
		"\u0001\u0000\u0000\u0000\u17ac\u17ad\u0001\u0000\u0000\u0000\u17ad\u17ae"+
		"\u0001\u0000\u0000\u0000\u17ae\u17af\u0005A\u0000\u0000\u17af\u17ba\u0003"+
		"\u0256\u012b\u0000\u17b0\u17b1\u0005\u009c\u0000\u0000\u17b1\u17b3\u0005"+
		"\u0083\u0000\u0000\u17b2\u17b4\u0005\u0011\u0000\u0000\u17b3\u17b2\u0001"+
		"\u0000\u0000\u0000\u17b3\u17b4\u0001\u0000\u0000\u0000\u17b4\u17b5\u0001"+
		"\u0000\u0000\u0000\u17b5\u17b7\u0005\u027d\u0000\u0000\u17b6\u17b8\u0003"+
		"\u01f8\u00fc\u0000\u17b7\u17b6\u0001\u0000\u0000\u0000\u17b7\u17b8\u0001"+
		"\u0000\u0000\u0000\u17b8\u17ba\u0001\u0000\u0000\u0000\u17b9\u16fa\u0001"+
		"\u0000\u0000\u0000\u17b9\u16fd\u0001\u0000\u0000\u0000\u17b9\u170b\u0001"+
		"\u0000\u0000\u0000\u17b9\u1721\u0001\u0000\u0000\u0000\u17b9\u1726\u0001"+
		"\u0000\u0000\u0000\u17b9\u1734\u0001\u0000\u0000\u0000\u17b9\u173b\u0001"+
		"\u0000\u0000\u0000\u17b9\u173f\u0001\u0000\u0000\u0000\u17b9\u1746\u0001"+
		"\u0000\u0000\u0000\u17b9\u174a\u0001\u0000\u0000\u0000\u17b9\u174f\u0001"+
		"\u0000\u0000\u0000\u17b9\u1752\u0001\u0000\u0000\u0000\u17b9\u1754\u0001"+
		"\u0000\u0000\u0000\u17b9\u1759\u0001\u0000\u0000\u0000\u17b9\u175f\u0001"+
		"\u0000\u0000\u0000\u17b9\u1768\u0001\u0000\u0000\u0000\u17b9\u176c\u0001"+
		"\u0000\u0000\u0000\u17b9\u1772\u0001\u0000\u0000\u0000\u17b9\u177e\u0001"+
		"\u0000\u0000\u0000\u17b9\u1788\u0001\u0000\u0000\u0000\u17b9\u179c\u0001"+
		"\u0000\u0000\u0000\u17b9\u17a7\u0001\u0000\u0000\u0000\u17b9\u17a9\u0001"+
		"\u0000\u0000\u0000\u17b9\u17b0\u0001\u0000\u0000\u0000\u17ba\u01f1\u0001"+
		"\u0000\u0000\u0000\u17bb\u17bd\u0005>\u0000\u0000\u17bc\u17be\u0003\u021a"+
		"\u010d\u0000\u17bd\u17bc\u0001\u0000\u0000\u0000\u17bd\u17be\u0001\u0000"+
		"\u0000\u0000\u17be\u17bf\u0001\u0000\u0000\u0000\u17bf\u17c0\u0005A\u0000"+
		"\u0000\u17c0\u17c1\u0005\u0178\u0000\u0000\u17c1\u17c2\u0003\u0256\u012b"+
		"\u0000\u17c2\u01f3\u0001\u0000\u0000\u0000\u17c3\u17ce\u0005\u049c\u0000"+
		"\u0000\u17c4\u17ce\u0005\u049d\u0000\u0000\u17c5\u17c6\u0005\u0486\u0000"+
		"\u0000\u17c6\u17c8\u0005\u0486\u0000\u0000\u17c7\u17c5\u0001\u0000\u0000"+
		"\u0000\u17c7\u17c8\u0001\u0000\u0000\u0000\u17c8\u17c9\u0001\u0000\u0000"+
		"\u0000\u17c9\u17cb\u0007Z\u0000\u0000\u17ca\u17c7\u0001\u0000\u0000\u0000"+
		"\u17ca\u17cb\u0001\u0000\u0000\u0000\u17cb\u17cc\u0001\u0000\u0000\u0000"+
		"\u17cc\u17ce\u0003\u0250\u0128\u0000\u17cd\u17c3\u0001\u0000\u0000\u0000"+
		"\u17cd\u17c4\u0001\u0000\u0000\u0000\u17cd\u17ca\u0001\u0000\u0000\u0000"+
		"\u17ce\u01f5\u0001\u0000\u0000\u0000\u17cf\u17d0\u0005\u001a\u0000\u0000"+
		"\u17d0\u17dd\u0005\u009a\u0000\u0000\u17d1\u17dd\u0005\u0353\u0000\u0000"+
		"\u17d2\u17dd\u0005)\u0000\u0000\u17d3\u17dd\u0005\u0098\u0000\u0000\u17d4"+
		"\u17d5\u0005\u01b5\u0000\u0000\u17d5\u17dd\u0005\u027d\u0000\u0000\u17d6"+
		"\u17d7\u0005\u0084\u0000\u0000\u17d7\u17dd\u0005\u027d\u0000\u0000\u17d8"+
		"\u17da\u0007:\u0000\u0000\u17d9\u17d8\u0001\u0000\u0000\u0000\u17d9\u17da"+
		"\u0001\u0000\u0000\u0000\u17da\u17db\u0001\u0000\u0000\u0000\u17db\u17dd"+
		"\u0007[\u0000\u0000\u17dc\u17cf\u0001\u0000\u0000\u0000\u17dc\u17d1\u0001"+
		"\u0000\u0000\u0000\u17dc\u17d2\u0001\u0000\u0000\u0000\u17dc\u17d3\u0001"+
		"\u0000\u0000\u0000\u17dc\u17d4\u0001\u0000\u0000\u0000\u17dc\u17d6\u0001"+
		"\u0000\u0000\u0000\u17dc\u17d9\u0001\u0000\u0000\u0000\u17dd\u01f7\u0001"+
		"\u0000\u0000\u0000\u17de\u17df\u0005b\u0000\u0000\u17df\u17e3\u0005\u0491"+
		"\u0000\u0000\u17e0\u17e1\u0005\u00be\u0000\u0000\u17e1\u17e3\u0003\u02ba"+
		"\u015d\u0000\u17e2\u17de\u0001\u0000\u0000\u0000\u17e2\u17e0\u0001\u0000"+
		"\u0000\u0000\u17e3\u01f9\u0001\u0000\u0000\u0000\u17e4\u17e6\u0005\u027f"+
		"\u0000\u0000\u17e5\u17e4\u0001\u0000\u0000\u0000\u17e5\u17e6\u0001\u0000"+
		"\u0000\u0000\u17e6\u17e7\u0001\u0000\u0000\u0000\u17e7\u1806\u0005\u019a"+
		"\u0000\u0000\u17e8\u17e9\u0007\\\u0000\u0000\u17e9\u1806\u0005\u027d\u0000"+
		"\u0000\u17ea\u17f0\u0005\u022d\u0000\u0000\u17eb\u17ee\u0005\u026e\u0000"+
		"\u0000\u17ec\u17ef\u0005\u0491\u0000\u0000\u17ed\u17ef\u0003\u01f8\u00fc"+
		"\u0000\u17ee\u17ec\u0001\u0000\u0000\u0000\u17ee\u17ed\u0001\u0000\u0000"+
		"\u0000\u17ef\u17f1\u0001\u0000\u0000\u0000\u17f0\u17eb\u0001\u0000\u0000"+
		"\u0000\u17f0\u17f1\u0001\u0000\u0000\u0000\u17f1\u1806\u0001\u0000\u0000"+
		"\u0000\u17f2\u1806\u0005\u02dc\u0000\u0000\u17f3\u17f5\u0005\u01b4\u0000"+
		"\u0000\u17f4\u17f3\u0001\u0000\u0000\u0000\u17f4\u17f5\u0001\u0000\u0000"+
		"\u0000\u17f5\u17f6\u0001\u0000\u0000\u0000\u17f6\u1806\u0005\u0234\u0000"+
		"\u0000\u17f7\u1806\u0005\u0236\u0000\u0000\u17f8\u1806\u0005\u01db\u0000"+
		"\u0000\u17f9\u17fa\u0007X\u0000\u0000\u17fa\u1806\u0005\u01bf\u0000\u0000"+
		"\u17fb\u1806\u0005\u0153\u0000\u0000\u17fc\u1806\u0005\u017f\u0000\u0000"+
		"\u17fd\u1806\u0005\u0239\u0000\u0000\u17fe\u17ff\u0005\u0006\u0000\u0000"+
		"\u17ff\u1800\u0007]\u0000\u0000\u1800\u1806\u0005\u027d\u0000\u0000\u1801"+
		"\u1806\u0005\u02ac\u0000\u0000\u1802\u1806\u0005\u02ad\u0000\u0000\u1803"+
		"\u1804\u0005\u00ac\u0000\u0000\u1804\u1806\u0005\u0294\u0000\u0000\u1805"+
		"\u17e5\u0001\u0000\u0000\u0000\u1805\u17e8\u0001\u0000\u0000\u0000\u1805"+
		"\u17ea\u0001\u0000\u0000\u0000\u1805\u17f2\u0001\u0000\u0000\u0000\u1805"+
		"\u17f4\u0001\u0000\u0000\u0000\u1805\u17f7\u0001\u0000\u0000\u0000\u1805"+
		"\u17f8\u0001\u0000\u0000\u0000\u1805\u17f9\u0001\u0000\u0000\u0000\u1805"+
		"\u17fb\u0001\u0000\u0000\u0000\u1805\u17fc\u0001\u0000\u0000\u0000\u1805"+
		"\u17fd\u0001\u0000\u0000\u0000\u1805\u17fe\u0001\u0000\u0000\u0000\u1805"+
		"\u1801\u0001\u0000\u0000\u0000\u1805\u1802\u0001\u0000\u0000\u0000\u1805"+
		"\u1803\u0001\u0000\u0000\u0000\u1806\u01fb\u0001\u0000\u0000\u0000\u1807"+
		"\u1810\u0005\u01a0\u0000\u0000\u1808\u1809\u0005\u00ac\u0000\u0000\u1809"+
		"\u1810\u0005\u027d\u0000\u0000\u180a\u180c\u0005\u01b4\u0000\u0000\u180b"+
		"\u180a\u0001\u0000\u0000\u0000\u180b\u180c\u0001\u0000\u0000\u0000\u180c"+
		"\u180d\u0001\u0000\u0000\u0000\u180d\u1810\u0005\u02ed\u0000\u0000\u180e"+
		"\u1810\u0005\u0292\u0000\u0000\u180f\u1807\u0001\u0000\u0000\u0000\u180f"+
		"\u1808\u0001\u0000\u0000\u0000\u180f\u180b\u0001\u0000\u0000\u0000\u180f"+
		"\u180e\u0001\u0000\u0000\u0000\u1810\u01fd\u0001\u0000\u0000\u0000\u1811"+
		"\u181e\u0005\u0006\u0000\u0000\u1812\u1813\u0005\u015b\u0000\u0000\u1813"+
		"\u181e\u0005\u01cd\u0000\u0000\u1814\u1815\u0005\u017e\u0000\u0000\u1815"+
		"\u181e\u0005\u0288\u0000\u0000\u1816\u181e\u0005\u0181\u0000\u0000\u1817"+
		"\u181e\u0005\u01cf\u0000\u0000\u1818\u181e\u0005\u031f\u0000\u0000\u1819"+
		"\u181a\u0005\u0221\u0000\u0000\u181a\u181e\u0005\u01aa\u0000\u0000\u181b"+
		"\u181e\u0005\u0270\u0000\u0000\u181c\u181e\u0005\u0287\u0000\u0000\u181d"+
		"\u1811\u0001\u0000\u0000\u0000\u181d\u1812\u0001\u0000\u0000\u0000\u181d"+
		"\u1814\u0001\u0000\u0000\u0000\u181d\u1816\u0001\u0000\u0000\u0000\u181d"+
		"\u1817\u0001\u0000\u0000\u0000\u181d\u1818\u0001\u0000\u0000\u0000\u181d"+
		"\u1819\u0001\u0000\u0000\u0000\u181d\u181b\u0001\u0000\u0000\u0000\u181d"+
		"\u181c\u0001\u0000\u0000\u0000\u181e\u01ff\u0001\u0000\u0000\u0000\u181f"+
		"\u1820\u0005\u0159\u0000\u0000\u1820\u1821\u0005\u0491\u0000\u0000\u1821"+
		"\u0201\u0001\u0000\u0000\u0000\u1822\u1823\u0005\u015f\u0000\u0000\u1823"+
		"\u1824\u0005Q\u0000\u0000\u1824\u1829\u0003\u020e\u0107\u0000\u1825\u1826"+
		"\u0005\u0484\u0000\u0000\u1826\u1828\u0003\u020e\u0107\u0000\u1827\u1825"+
		"\u0001\u0000\u0000\u0000\u1828\u182b\u0001\u0000\u0000\u0000\u1829\u1827"+
		"\u0001\u0000\u0000\u0000\u1829\u182a\u0001\u0000\u0000\u0000\u182a\u1833"+
		"\u0001\u0000\u0000\u0000\u182b\u1829\u0001\u0000\u0000\u0000\u182c\u182d"+
		"\u0005\u0081\u0000\u0000\u182d\u1830\u0005\u0482\u0000\u0000\u182e\u1831"+
		"\u0003\u0272\u0139\u0000\u182f\u1831\u0005\u0006\u0000\u0000\u1830\u182e"+
		"\u0001\u0000\u0000\u0000\u1830\u182f\u0001\u0000\u0000\u0000\u1831\u1832"+
		"\u0001\u0000\u0000\u0000\u1832\u1834\u0005\u0483\u0000\u0000\u1833\u182c"+
		"\u0001\u0000\u0000\u0000\u1833\u1834\u0001\u0000\u0000\u0000\u1834\u1835"+
		"\u0001\u0000\u0000\u0000\u1835\u1836\u0005P\u0000\u0000\u1836\u1837\u0003"+
		"\u0250\u0128\u0000\u1837\u0203\u0001\u0000\u0000\u0000\u1838\u183a\u0005"+
		"\u01b0\u0000\u0000\u1839\u183b\u0007N\u0000\u0000\u183a\u1839\u0001\u0000"+
		"\u0000\u0000\u183a\u183b\u0001\u0000\u0000\u0000\u183b\u183c\u0001\u0000"+
		"\u0000\u0000\u183c\u1841\u0003\u0210\u0108\u0000\u183d\u183e\u0005\u0484"+
		"\u0000\u0000\u183e\u1840\u0003\u0210\u0108\u0000\u183f\u183d\u0001\u0000"+
		"\u0000\u0000\u1840\u1843\u0001\u0000\u0000\u0000\u1841\u183f\u0001\u0000"+
		"\u0000\u0000\u1841\u1842\u0001\u0000\u0000\u0000\u1842\u1847\u0001\u0000"+
		"\u0000\u0000\u1843\u1841\u0001\u0000\u0000\u0000\u1844\u1845\u0005\u01b0"+
		"\u0000\u0000\u1845\u1847\u0007Y\u0000\u0000\u1846\u1838\u0001\u0000\u0000"+
		"\u0000\u1846\u1844\u0001\u0000\u0000\u0000\u1847\u0205\u0001\u0000\u0000"+
		"\u0000\u1848\u184a\u0005]\u0000\u0000\u1849\u184b\u0007^\u0000\u0000\u184a"+
		"\u1849\u0001\u0000\u0000\u0000\u184a\u184b\u0001\u0000\u0000\u0000\u184b"+
		"\u184c\u0001\u0000\u0000\u0000\u184c\u184d\u0003\u02ba\u015d\u0000\u184d"+
		"\u0207\u0001\u0000\u0000\u0000\u184e\u184f\u0005f\u0000\u0000\u184f\u1850"+
		"\u0005Q\u0000\u0000\u1850\u1851\u0005W\u0000\u0000\u1851\u1852\u0005\u015f"+
		"\u0000\u0000\u1852\u1857\u0003\u0214\u010a\u0000\u1853\u1854\u0005\u0484"+
		"\u0000\u0000\u1854\u1856\u0003\u0214\u010a\u0000\u1855\u1853\u0001\u0000"+
		"\u0000\u0000\u1856\u1859\u0001\u0000\u0000\u0000\u1857\u1855\u0001\u0000"+
		"\u0000\u0000\u1857\u1858\u0001\u0000\u0000\u0000\u1858\u0209\u0001\u0000"+
		"\u0000\u0000\u1859\u1857\u0001\u0000\u0000\u0000\u185a\u185b\u0005\u024f"+
		"\u0000\u0000\u185b\u185c\u0005\u0238\u0000\u0000\u185c\u185d\u0005\u015f"+
		"\u0000\u0000\u185d\u020b\u0001\u0000\u0000\u0000\u185e\u185f\u0005\u02ea"+
		"\u0000\u0000\u185f\u020d\u0001\u0000\u0000\u0000\u1860\u1868\u0003\u022e"+
		"\u0117\u0000\u1861\u1863\u0007\u0017\u0000\u0000\u1862\u1861\u0001\u0000"+
		"\u0000\u0000\u1862\u1863\u0001\u0000\u0000\u0000\u1863\u1864\u0001\u0000"+
		"\u0000\u0000\u1864\u1865\u0005\u0482\u0000\u0000\u1865\u1866\u0003\u0272"+
		"\u0139\u0000\u1866\u1867\u0005\u0483\u0000\u0000\u1867\u1869\u0001\u0000"+
		"\u0000\u0000\u1868\u1862\u0001\u0000\u0000\u0000\u1868\u1869\u0001\u0000"+
		"\u0000\u0000\u1869\u020f\u0001\u0000\u0000\u0000\u186a\u187d\u0005\u018a"+
		"\u0000\u0000\u186b\u187d\u0005\u01bf\u0000\u0000\u186c\u186e\u0007_\u0000"+
		"\u0000\u186d\u186c\u0001\u0000\u0000\u0000\u186d\u186e\u0001\u0000\u0000"+
		"\u0000\u186e\u186f\u0001\u0000\u0000\u0000\u186f\u187d\u0005\u01dd\u0000"+
		"\u0000\u1870\u187d\u0005\u021d\u0000\u0000\u1871\u187d\u0005\u02dc\u0000"+
		"\u0000\u1872\u1873\u0005\u0238\u0000\u0000\u1873\u187d\u0005\u015f\u0000"+
		"\u0000\u1874\u187d\u0005\u027d\u0000\u0000\u1875\u187d\u0005\u029f\u0000"+
		"\u0000\u1876\u187a\u0005\u02ed\u0000\u0000\u1877\u1878\u0005\u00c0\u0000"+
		"\u0000\u1878\u1879\u0005\u0087\u0000\u0000\u1879\u187b\u0005g\u0000\u0000"+
		"\u187a\u1877\u0001\u0000\u0000\u0000\u187a\u187b\u0001\u0000\u0000\u0000"+
		"\u187b\u187d\u0001\u0000\u0000\u0000\u187c\u186a\u0001\u0000\u0000\u0000"+
		"\u187c\u186b\u0001\u0000\u0000\u0000\u187c\u186d\u0001\u0000\u0000\u0000"+
		"\u187c\u1870\u0001\u0000\u0000\u0000\u187c\u1871\u0001\u0000\u0000\u0000"+
		"\u187c\u1872\u0001\u0000\u0000\u0000\u187c\u1874\u0001\u0000\u0000\u0000"+
		"\u187c\u1875\u0001\u0000\u0000\u0000\u187c\u1876\u0001\u0000\u0000\u0000"+
		"\u187d\u188b\u0001\u0000\u0000\u0000\u187e\u187f\u0005\u0240\u0000\u0000"+
		"\u187f\u1881\u0005\u01dd\u0000\u0000\u1880\u1882\u0003\u016c\u00b6\u0000"+
		"\u1881\u1880\u0001\u0000\u0000\u0000\u1881\u1882\u0001\u0000\u0000\u0000"+
		"\u1882\u188b\u0001\u0000\u0000\u0000\u1883\u1885\u00079\u0000\u0000\u1884"+
		"\u1886\u0003\u0274\u013a\u0000\u1885\u1884\u0001\u0000\u0000\u0000\u1885"+
		"\u1886\u0001\u0000\u0000\u0000\u1886\u1888\u0001\u0000\u0000\u0000\u1887"+
		"\u1889\u0003\u0212\u0109\u0000\u1888\u1887\u0001\u0000\u0000\u0000\u1888"+
		"\u1889\u0001\u0000\u0000\u0000\u1889\u188b\u0001\u0000\u0000\u0000\u188a"+
		"\u187c\u0001\u0000\u0000\u0000\u188a\u187e\u0001\u0000\u0000\u0000\u188a"+
		"\u1883\u0001\u0000\u0000\u0000\u188b\u0211\u0001\u0000\u0000\u0000\u188c"+
		"\u188d\u0005\u00c0\u0000\u0000\u188d\u188e\u0005\u0087\u0000\u0000\u188e"+
		"\u1892\u0005g\u0000\u0000\u188f\u1890\u0005A\u0000\u0000\u1890\u1892\u0005"+
		"\u01a5\u0000\u0000\u1891\u188c\u0001\u0000\u0000\u0000\u1891\u188f\u0001"+
		"\u0000\u0000\u0000\u1892\u0213\u0001\u0000\u0000\u0000\u1893\u189b\u0003"+
		"\u022e\u0117\u0000\u1894\u1895\u0005\u0081\u0000\u0000\u1895\u1898\u0005"+
		"\u0482\u0000\u0000\u1896\u1899\u0003\u0272\u0139\u0000\u1897\u1899\u0005"+
		"\u0006\u0000\u0000\u1898\u1896\u0001\u0000\u0000\u0000\u1898\u1897\u0001"+
		"\u0000\u0000\u0000\u1899\u189a\u0001\u0000\u0000\u0000\u189a\u189c\u0005"+
		"\u0483\u0000\u0000\u189b\u1894\u0001\u0000\u0000\u0000\u189b\u189c\u0001"+
		"\u0000\u0000\u0000\u189c\u18a4\u0001\u0000\u0000\u0000\u189d\u189f\u0007"+
		"\u0017\u0000\u0000\u189e\u189d\u0001\u0000\u0000\u0000\u189e\u189f\u0001"+
		"\u0000\u0000\u0000\u189f\u18a0\u0001\u0000\u0000\u0000\u18a0\u18a1\u0005"+
		"\u0482\u0000\u0000\u18a1\u18a2\u0003\u0272\u0139\u0000\u18a2\u18a3\u0005"+
		"\u0483\u0000\u0000\u18a3\u18a5\u0001\u0000\u0000\u0000\u18a4\u189e\u0001"+
		"\u0000\u0000\u0000\u18a4\u18a5\u0001\u0000\u0000\u0000\u18a5\u18a8\u0001"+
		"\u0000\u0000\u0000\u18a6\u18a7\u0005N\u0000\u0000\u18a7\u18a9\u0005\u01d6"+
		"\u0000\u0000\u18a8\u18a6\u0001\u0000\u0000\u0000\u18a8\u18a9\u0001\u0000"+
		"\u0000\u0000\u18a9\u0215\u0001\u0000\u0000\u0000\u18aa\u18ab\u0007`\u0000"+
		"\u0000\u18ab\u18ae\u0003\u022e\u0117\u0000\u18ac\u18af\u0003\u0250\u0128"+
		"\u0000\u18ad\u18af\u0005\u0491\u0000\u0000\u18ae\u18ac\u0001\u0000\u0000"+
		"\u0000\u18ae\u18ad\u0001\u0000\u0000\u0000\u18ae\u18af\u0001\u0000\u0000"+
		"\u0000\u18af\u0217\u0001\u0000\u0000\u0000\u18b0\u18b4\u0007`\u0000\u0000"+
		"\u18b1\u18b2\u0007a\u0000\u0000\u18b2\u18b3\u0005\u0479\u0000\u0000\u18b3"+
		"\u18b5\u0007b\u0000\u0000\u18b4\u18b1\u0001\u0000\u0000\u0000\u18b4\u18b5"+
		"\u0001\u0000\u0000\u0000\u18b5\u18b6\u0001\u0000\u0000\u0000\u18b6\u18b7"+
		"\u0003\u022a\u0115\u0000\u18b7\u0219\u0001\u0000\u0000\u0000\u18b8\u18b9"+
		"\u0005\u037c\u0000\u0000\u18b9\u18ba\u0005\u0479\u0000\u0000\u18ba\u18bb"+
		"\u0005\u01d2\u0000\u0000\u18bb\u021b\u0001\u0000\u0000\u0000\u18bc\u18bd"+
		"\u0005\u01bc\u0000\u0000\u18bd\u18be\u0005\u0491\u0000\u0000\u18be\u021d"+
		"\u0001\u0000\u0000\u0000\u18bf\u18c0\u0005\u00ba\u0000\u0000\u18c0\u18c1"+
		"\u0003\u0250\u0128\u0000\u18c1\u021f\u0001\u0000\u0000\u0000\u18c2\u18ca"+
		"\u0005\u009d\u0000\u0000\u18c3\u18c5\u0005\u00a2\u0000\u0000\u18c4\u18c6"+
		"\u0005\u02a1\u0000\u0000\u18c5\u18c4\u0001\u0000\u0000\u0000\u18c5\u18c6"+
		"\u0001\u0000\u0000\u0000\u18c6\u18c7\u0001\u0000\u0000\u0000\u18c7\u18cb"+
		"\u0003\u025a\u012d\u0000\u18c8\u18cb\u0005\u0499\u0000\u0000\u18c9\u18cb"+
		"\u0005\u049a\u0000\u0000\u18ca\u18c3\u0001\u0000\u0000\u0000\u18ca\u18c8"+
		"\u0001\u0000\u0000\u0000\u18ca\u18c9\u0001\u0000\u0000\u0000\u18cb\u18d5"+
		"\u0001\u0000\u0000\u0000\u18cc\u18cd\u0005\u009a\u0000\u0000\u18cd\u18d2"+
		"\u0003\u0224\u0112\u0000\u18ce\u18cf\u0005\u0484\u0000\u0000\u18cf\u18d1"+
		"\u0003\u0224\u0112\u0000\u18d0\u18ce\u0001\u0000\u0000\u0000\u18d1\u18d4"+
		"\u0001\u0000\u0000\u0000\u18d2\u18d0\u0001\u0000\u0000\u0000\u18d2\u18d3"+
		"\u0001\u0000\u0000\u0000\u18d3\u18d6\u0001\u0000\u0000\u0000\u18d4\u18d2"+
		"\u0001\u0000\u0000\u0000\u18d5\u18cc\u0001\u0000\u0000\u0000\u18d5\u18d6"+
		"\u0001\u0000\u0000\u0000\u18d6\u0221\u0001\u0000\u0000\u0000\u18d7\u18df"+
		"\u0005\u0090\u0000\u0000\u18d8\u18da\u0005\u00a2\u0000\u0000\u18d9\u18db"+
		"\u0005\u02a1\u0000\u0000\u18da\u18d9\u0001\u0000\u0000\u0000\u18da\u18db"+
		"\u0001\u0000\u0000\u0000\u18db\u18dc\u0001\u0000\u0000\u0000\u18dc\u18e0"+
		"\u0003\u025a\u012d\u0000\u18dd\u18e0\u0005\u0499\u0000\u0000\u18de\u18e0"+
		"\u0005\u049a\u0000\u0000\u18df\u18d8\u0001\u0000\u0000\u0000\u18df\u18dd"+
		"\u0001\u0000\u0000\u0000\u18df\u18de\u0001\u0000\u0000\u0000\u18df\u18e0"+
		"\u0001\u0000\u0000\u0000\u18e0\u18ea\u0001\u0000\u0000\u0000\u18e1\u18e2"+
		"\u0005\u009a\u0000\u0000\u18e2\u18e7\u0003\u0224\u0112\u0000\u18e3\u18e4"+
		"\u0005\u0484\u0000\u0000\u18e4\u18e6\u0003\u0224\u0112\u0000\u18e5\u18e3"+
		"\u0001\u0000\u0000\u0000\u18e6\u18e9\u0001\u0000\u0000\u0000\u18e7\u18e5"+
		"\u0001\u0000\u0000\u0000\u18e7\u18e8\u0001\u0000\u0000\u0000\u18e8\u18eb"+
		"\u0001\u0000\u0000\u0000\u18e9\u18e7\u0001\u0000\u0000\u0000\u18ea\u18e1"+
		"\u0001\u0000\u0000\u0000\u18ea\u18eb\u0001\u0000\u0000\u0000\u18eb\u0223"+
		"\u0001\u0000\u0000\u0000\u18ec\u18ed\u0007c\u0000\u0000\u18ed\u18f2\u0005"+
		"\u0479\u0000\u0000\u18ee\u18f3\u0003\u025a\u012d\u0000\u18ef\u18f3\u0005"+
		"\u0492\u0000\u0000\u18f0\u18f3\u0003\u023c\u011e\u0000\u18f1\u18f3\u0003"+
		"\u0252\u0129\u0000\u18f2\u18ee\u0001\u0000\u0000\u0000\u18f2\u18ef\u0001"+
		"\u0000\u0000\u0000\u18f2\u18f0\u0001\u0000\u0000\u0000\u18f2\u18f1\u0001"+
		"\u0000\u0000\u0000\u18f3\u0225\u0001\u0000\u0000\u0000\u18f4\u18f6\u0005"+
		"G\u0000\u0000\u18f5\u18f7\u0007d\u0000\u0000\u18f6\u18f5\u0001\u0000\u0000"+
		"\u0000\u18f6\u18f7\u0001\u0000\u0000\u0000\u18f7\u18f8\u0001\u0000\u0000"+
		"\u0000\u18f8\u1918\u00051\u0000\u0000\u18f9\u18fa\u0003\u01f4\u00fa\u0000"+
		"\u18fa\u18fb\u0005\u0479\u0000\u0000\u18fb\u1903\u0007e\u0000\u0000\u18fc"+
		"\u18fd\u0005\u0484\u0000\u0000\u18fd\u18fe\u0003\u01f4\u00fa\u0000\u18fe"+
		"\u18ff\u0005\u0479\u0000\u0000\u18ff\u1900\u0007e\u0000\u0000\u1900\u1902"+
		"\u0001\u0000\u0000\u0000\u1901\u18fc\u0001\u0000\u0000\u0000\u1902\u1905"+
		"\u0001\u0000\u0000\u0000\u1903\u1901\u0001\u0000\u0000\u0000\u1903\u1904"+
		"\u0001\u0000\u0000\u0000\u1904\u1919\u0001\u0000\u0000\u0000\u1905\u1903"+
		"\u0001\u0000\u0000\u0000\u1906\u1909\u0005\u001e\u0000\u0000\u1907\u190a"+
		"\u0003\u0256\u012b\u0000\u1908\u190a\u0003\u01f4\u00fa\u0000\u1909\u1907"+
		"\u0001\u0000\u0000\u0000\u1909\u1908\u0001\u0000\u0000\u0000\u190a\u190b"+
		"\u0001\u0000\u0000\u0000\u190b\u190c\u0003\u01f4\u00fa\u0000\u190c\u190d"+
		"\u0005\u0479\u0000\u0000\u190d\u1915\u0003\u0228\u0114\u0000\u190e\u190f"+
		"\u0005\u0484\u0000\u0000\u190f\u1910\u0003\u01f4\u00fa\u0000\u1910\u1911"+
		"\u0005\u0479\u0000\u0000\u1911\u1912\u0003\u0228\u0114\u0000\u1912\u1914"+
		"\u0001\u0000\u0000\u0000\u1913\u190e\u0001\u0000\u0000\u0000\u1914\u1917"+
		"\u0001\u0000\u0000\u0000\u1915\u1913\u0001\u0000\u0000\u0000\u1915\u1916"+
		"\u0001\u0000\u0000\u0000\u1916\u1919\u0001\u0000\u0000\u0000\u1917\u1915"+
		"\u0001\u0000\u0000\u0000\u1918\u18f9\u0001\u0000\u0000\u0000\u1918\u1906"+
		"\u0001\u0000\u0000\u0000\u1919\u0227\u0001\u0000\u0000\u0000\u191a\u191b"+
		"\u0007f\u0000\u0000\u191b\u0229\u0001\u0000\u0000\u0000\u191c\u1922\u0003"+
		"\u00d2i\u0000\u191d\u1922\u0003\u00c4b\u0000\u191e\u1922\u0003\u00cae"+
		"\u0000\u191f\u1922\u0003\u00d0h\u0000\u1920\u1922\u0003\u00d4j\u0000\u1921"+
		"\u191c\u0001\u0000\u0000\u0000\u1921\u191d\u0001\u0000\u0000\u0000\u1921"+
		"\u191e\u0001\u0000\u0000\u0000\u1921\u191f\u0001\u0000\u0000\u0000\u1921"+
		"\u1920\u0001\u0000\u0000\u0000\u1922\u1927\u0001\u0000\u0000\u0000\u1923"+
		"\u1924\u0005A\u0000\u0000\u1924\u1925\u0005\u0178\u0000\u0000\u1925\u1927"+
		"\u0003\u0250\u0128\u0000\u1926\u1921\u0001\u0000\u0000\u0000\u1926\u1923"+
		"\u0001\u0000\u0000\u0000\u1927\u022b\u0001\u0000\u0000\u0000\u1928\u192c"+
		"\u0003\u0250\u0128\u0000\u1929\u192d\u0005\u0498\u0000\u0000\u192a\u192b"+
		"\u0005\u0481\u0000\u0000\u192b\u192d\u0003\u0250\u0128\u0000\u192c\u1929"+
		"\u0001\u0000\u0000\u0000\u192c\u192a\u0001\u0000\u0000\u0000\u192c\u192d"+
		"\u0001\u0000\u0000\u0000\u192d\u022d\u0001\u0000\u0000\u0000\u192e\u192f"+
		"\u0003\u022c\u0116\u0000\u192f\u022f\u0001\u0000\u0000\u0000\u1930\u1933"+
		"\u0003\u023a\u011d\u0000\u1931\u1933\u0003\u0250\u0128\u0000\u1932\u1930"+
		"\u0001\u0000\u0000\u0000\u1932\u1931\u0001\u0000\u0000\u0000\u1933\u0231"+
		"\u0001\u0000\u0000\u0000\u1934\u1939\u0003\u0250\u0128\u0000\u1935\u1937"+
		"\u0003\u0254\u012a\u0000\u1936\u1938\u0003\u0254\u012a\u0000\u1937\u1936"+
		"\u0001\u0000\u0000\u0000\u1937\u1938\u0001\u0000\u0000\u0000\u1938\u193a"+
		"\u0001\u0000\u0000\u0000\u1939\u1935\u0001\u0000\u0000\u0000\u1939\u193a"+
		"\u0001\u0000\u0000\u0000\u193a\u1941\u0001\u0000\u0000\u0000\u193b\u193c"+
		"\t\u0000\u0000\u0000\u193c\u193e\u0003\u0254\u012a\u0000\u193d\u193f\u0003"+
		"\u0254\u012a\u0000\u193e\u193d\u0001\u0000\u0000\u0000\u193e\u193f\u0001"+
		"\u0000\u0000\u0000\u193f\u1941\u0001\u0000\u0000\u0000\u1940\u1934\u0001"+
		"\u0000\u0000\u0000\u1940\u193b\u0001\u0000\u0000\u0000\u1941\u0233\u0001"+
		"\u0000\u0000\u0000\u1942\u1945\u0003\u0250\u0128\u0000\u1943\u1945\u0005"+
		"\u0491\u0000\u0000\u1944\u1942\u0001\u0000\u0000\u0000\u1944\u1943\u0001"+
		"\u0000\u0000\u0000\u1945\u194a\u0001\u0000\u0000\u0000\u1946\u1947\u0005"+
		"\u0482\u0000\u0000\u1947\u1948\u0003\u0256\u012b\u0000\u1948\u1949\u0005"+
		"\u0483\u0000\u0000\u1949\u194b\u0001\u0000\u0000\u0000\u194a\u1946\u0001"+
		"\u0000\u0000\u0000\u194a\u194b\u0001\u0000\u0000\u0000\u194b\u194e\u0001"+
		"\u0000\u0000\u0000\u194c\u194e\u0003\u02ba\u015d\u0000\u194d\u1944\u0001"+
		"\u0000\u0000\u0000\u194d\u194c\u0001\u0000\u0000\u0000\u194e\u1950\u0001"+
		"\u0000\u0000\u0000\u194f\u1951\u00073\u0000\u0000\u1950\u194f\u0001\u0000"+
		"\u0000\u0000\u1950\u1951\u0001\u0000\u0000\u0000\u1951\u0235\u0001\u0000"+
		"\u0000\u0000\u1952\u1957\u0005\u0491\u0000\u0000\u1953\u1957\u0005\u0499"+
		"\u0000\u0000\u1954\u1957\u0005\u02c3\u0000\u0000\u1955\u1957\u0003\u02d6"+
		"\u016b\u0000\u1956\u1952\u0001\u0000\u0000\u0000\u1956\u1953\u0001\u0000"+
		"\u0000\u0000\u1956\u1954\u0001\u0000\u0000\u0000\u1956\u1955\u0001\u0000"+
		"\u0000\u0000\u1957\u0237\u0001\u0000\u0000\u0000\u1958\u1959\u0007g\u0000"+
		"\u0000\u1959\u0239\u0001\u0000\u0000\u0000\u195a\u1960\u0003\u0236\u011b"+
		"\u0000\u195b\u195c\u0003\u0236\u011b\u0000\u195c\u195d\u0003\u0238\u011c"+
		"\u0000\u195d\u1960\u0001\u0000\u0000\u0000\u195e\u1960\u0003D\"\u0000"+
		"\u195f\u195a\u0001\u0000\u0000\u0000\u195f\u195b\u0001\u0000\u0000\u0000"+
		"\u195f\u195e\u0001\u0000\u0000\u0000\u1960\u023b\u0001\u0000\u0000\u0000"+
		"\u1961\u1962\u0007h\u0000\u0000\u1962\u023d\u0001\u0000\u0000\u0000\u1963"+
		"\u1968\u0005\u00e2\u0000\u0000\u1964\u1968\u0003\u02cc\u0166\u0000\u1965"+
		"\u1968\u0005\u0491\u0000\u0000\u1966\u1968\u0005\u048e\u0000\u0000\u1967"+
		"\u1963\u0001\u0000\u0000\u0000\u1967\u1964\u0001\u0000\u0000\u0000\u1967"+
		"\u1965\u0001\u0000\u0000\u0000\u1967\u1966\u0001\u0000\u0000\u0000\u1968"+
		"\u023f\u0001\u0000\u0000\u0000\u1969\u196c\u0003\u0250\u0128\u0000\u196a"+
		"\u196c\u0005\u0491\u0000\u0000\u196b\u1969\u0001\u0000\u0000\u0000\u196b"+
		"\u196a\u0001\u0000\u0000\u0000\u196c\u0241\u0001\u0000\u0000\u0000\u196d"+
		"\u1971\u0003\u0244\u0122\u0000\u196e\u1971\u0005\u0499\u0000\u0000\u196f"+
		"\u1971\u0005\u0491\u0000\u0000\u1970\u196d\u0001\u0000\u0000\u0000\u1970"+
		"\u196e\u0001\u0000\u0000\u0000\u1970\u196f\u0001\u0000\u0000\u0000\u1971"+
		"\u0243\u0001\u0000\u0000\u0000\u1972\u1973\u0007i\u0000\u0000\u1973\u0245"+
		"\u0001\u0000\u0000\u0000\u1974\u1975\u0007j\u0000\u0000\u1975\u0247\u0001"+
		"\u0000\u0000\u0000\u1976\u1977\u0003\u0256\u012b\u0000\u1977\u1978\u0005"+
		"\u0476\u0000\u0000\u1978\u1979\u0003\u0256\u012b\u0000\u1979\u197a\u0005"+
		"\u0476\u0000\u0000\u197a\u197b\u0003\u0256\u012b\u0000\u197b\u197c\u0005"+
		"\u0476\u0000\u0000\u197c\u197d\u0003\u0256\u012b\u0000\u197d\u197e\u0005"+
		"\u0476\u0000\u0000\u197e\u1984\u0003\u0256\u012b\u0000\u197f\u1980\u0005"+
		"\u048d\u0000\u0000\u1980\u1981\u0003\u0256\u012b\u0000\u1981\u1982\u0005"+
		"\u0476\u0000\u0000\u1982\u1983\u0003\u0256\u012b\u0000\u1983\u1985\u0001"+
		"\u0000\u0000\u0000\u1984\u197f\u0001\u0000\u0000\u0000\u1985\u1986\u0001"+
		"\u0000\u0000\u0000\u1986\u1984\u0001\u0000\u0000\u0000\u1986\u1987\u0001"+
		"\u0000\u0000\u0000\u1987\u0249\u0001\u0000\u0000\u0000\u1988\u198f\u0003"+
		"\u024c\u0126\u0000\u1989\u198a\u0005\u0484\u0000\u0000\u198a\u198d\u0003"+
		"\u024c\u0126\u0000\u198b\u198c\u0005\u0484\u0000\u0000\u198c\u198e\u0003"+
		"\u0256\u012b\u0000\u198d\u198b\u0001\u0000\u0000\u0000\u198d\u198e\u0001"+
		"\u0000\u0000\u0000\u198e\u1990\u0001\u0000\u0000\u0000\u198f\u1989\u0001"+
		"\u0000\u0000\u0000\u198f\u1990\u0001\u0000\u0000\u0000\u1990\u024b\u0001"+
		"\u0000\u0000\u0000\u1991\u1999\u0005\u0491\u0000\u0000\u1992\u1999\u0005"+
		"\u0496\u0000\u0000\u1993\u1995\u0005\u0493\u0000\u0000\u1994\u1993\u0001"+
		"\u0000\u0000\u0000\u1995\u1996\u0001\u0000\u0000\u0000\u1996\u1994\u0001"+
		"\u0000\u0000\u0000\u1996\u1997\u0001\u0000\u0000\u0000\u1997\u1999\u0001"+
		"\u0000\u0000\u0000\u1998\u1991\u0001\u0000\u0000\u0000\u1998\u1992\u0001"+
		"\u0000\u0000\u0000\u1998\u1994\u0001\u0000\u0000\u0000\u1999\u024d\u0001"+
		"\u0000\u0000\u0000\u199a\u199d\u0003\u0250\u0128\u0000\u199b\u199d\u0005"+
		"\u0491\u0000\u0000\u199c\u199a\u0001\u0000\u0000\u0000\u199c\u199b\u0001"+
		"\u0000\u0000\u0000\u199d\u024f\u0001\u0000\u0000\u0000\u199e\u19a2\u0003"+
		"\u0252\u0129\u0000\u199f\u19a2\u0005\u048e\u0000\u0000\u19a0\u19a2\u0005"+
		"\u0491\u0000\u0000\u19a1\u199e\u0001\u0000\u0000\u0000\u19a1\u199f\u0001"+
		"\u0000\u0000\u0000\u19a1\u19a0\u0001\u0000\u0000\u0000\u19a2\u0251\u0001"+
		"\u0000\u0000\u0000\u19a3\u19ad\u0005\u0499\u0000\u0000\u19a4\u19ad\u0003"+
		"\u02cc\u0166\u0000\u19a5\u19ad\u0003\u02ce\u0167\u0000\u19a6\u19ad\u0003"+
		"\u0244\u0122\u0000\u19a7\u19ad\u0003\u02d0\u0168\u0000\u19a8\u19ad\u0003"+
		"\u02d2\u0169\u0000\u19a9\u19ad\u0003\u02d4\u016a\u0000\u19aa\u19ad\u0003"+
		"\u02d6\u016b\u0000\u19ab\u19ad\u0003\u02b2\u0159\u0000\u19ac\u19a3\u0001"+
		"\u0000\u0000\u0000\u19ac\u19a4\u0001\u0000\u0000\u0000\u19ac\u19a5\u0001"+
		"\u0000\u0000\u0000\u19ac\u19a6\u0001\u0000\u0000\u0000\u19ac\u19a7\u0001"+
		"\u0000\u0000\u0000\u19ac\u19a8\u0001\u0000\u0000\u0000\u19ac\u19a9\u0001"+
		"\u0000\u0000\u0000\u19ac\u19aa\u0001\u0000\u0000\u0000\u19ac\u19ab\u0001"+
		"\u0000\u0000\u0000\u19ad\u0253\u0001\u0000\u0000\u0000\u19ae\u19b2\u0005"+
		"\u0498\u0000\u0000\u19af\u19b0\u0005\u0481\u0000\u0000\u19b0\u19b2\u0003"+
		"\u0250\u0128\u0000\u19b1\u19ae\u0001\u0000\u0000\u0000\u19b1\u19af\u0001"+
		"\u0000\u0000\u0000\u19b2\u0255\u0001\u0000\u0000\u0000\u19b3\u19b4\u0007"+
		"k\u0000\u0000\u19b4\u0257\u0001\u0000\u0000\u0000\u19b5\u19b8\u0005\u048f"+
		"\u0000\u0000\u19b6\u19b8\u0003\u0256\u012b\u0000\u19b7\u19b5\u0001\u0000"+
		"\u0000\u0000\u19b7\u19b6\u0001\u0000\u0000\u0000\u19b8\u0259\u0001\u0000"+
		"\u0000\u0000\u19b9\u19bb\u0005\u0497\u0000\u0000\u19ba\u19b9\u0001\u0000"+
		"\u0000\u0000\u19ba\u19bb\u0001\u0000\u0000\u0000\u19bb\u19bc\u0001\u0000"+
		"\u0000\u0000\u19bc\u19bf\u0005\u0491\u0000\u0000\u19bd\u19bf\u0005\u0490"+
		"\u0000\u0000\u19be\u19ba\u0001\u0000\u0000\u0000\u19be\u19bd\u0001\u0000"+
		"\u0000\u0000\u19bf\u19c1\u0001\u0000\u0000\u0000\u19c0\u19c2\u0005\u0491"+
		"\u0000\u0000\u19c1\u19c0\u0001\u0000\u0000\u0000\u19c2\u19c3\u0001\u0000"+
		"\u0000\u0000\u19c3\u19c1\u0001\u0000\u0000\u0000\u19c3\u19c4\u0001\u0000"+
		"\u0000\u0000\u19c4\u19d1\u0001\u0000\u0000\u0000\u19c5\u19c7\u0005\u0497"+
		"\u0000\u0000\u19c6\u19c5\u0001\u0000\u0000\u0000\u19c6\u19c7\u0001\u0000"+
		"\u0000\u0000\u19c7\u19c8\u0001\u0000\u0000\u0000\u19c8\u19cb\u0005\u0491"+
		"\u0000\u0000\u19c9\u19cb\u0005\u0490\u0000\u0000\u19ca\u19c6\u0001\u0000"+
		"\u0000\u0000\u19ca\u19c9\u0001\u0000\u0000\u0000\u19cb\u19ce\u0001\u0000"+
		"\u0000\u0000\u19cc\u19cd\u0005\u001c\u0000\u0000\u19cd\u19cf\u0003\u0240"+
		"\u0120\u0000\u19ce\u19cc\u0001\u0000\u0000\u0000\u19ce\u19cf\u0001\u0000"+
		"\u0000\u0000\u19cf\u19d1\u0001\u0000\u0000\u0000\u19d0\u19be\u0001\u0000"+
		"\u0000\u0000\u19d0\u19ca\u0001\u0000\u0000\u0000\u19d1\u025b\u0001\u0000"+
		"\u0000\u0000\u19d2\u19d3\u0007l\u0000\u0000\u19d3\u025d\u0001\u0000\u0000"+
		"\u0000\u19d4\u19d6\u0005\u0497\u0000\u0000\u19d5\u19d4\u0001\u0000\u0000"+
		"\u0000\u19d5\u19d6\u0001\u0000\u0000\u0000\u19d6\u19d7\u0001\u0000\u0000"+
		"\u0000\u19d7\u19d8\u0005\u0493\u0000\u0000\u19d8\u025f\u0001\u0000\u0000"+
		"\u0000\u19d9\u19db\u0005r\u0000\u0000\u19da\u19d9\u0001\u0000\u0000\u0000"+
		"\u19da\u19db\u0001\u0000\u0000\u0000\u19db\u19dc\u0001\u0000\u0000\u0000"+
		"\u19dc\u19dd\u0007m\u0000\u0000\u19dd\u0261\u0001\u0000\u0000\u0000\u19de"+
		"\u19eb\u0003\u025a\u012d\u0000\u19df\u19eb\u0003\u0256\u012b\u0000\u19e0"+
		"\u19e1\u0005\u0476\u0000\u0000\u19e1\u19eb\u0003\u0256\u012b\u0000\u19e2"+
		"\u19eb\u0003\u025e\u012f\u0000\u19e3\u19eb\u0003\u025c\u012e\u0000\u19e4"+
		"\u19eb\u0005\u0494\u0000\u0000\u19e5\u19eb\u0005\u0496\u0000\u0000\u19e6"+
		"\u19e8\u0005r\u0000\u0000\u19e7\u19e6\u0001\u0000\u0000\u0000\u19e7\u19e8"+
		"\u0001\u0000\u0000\u0000\u19e8\u19e9\u0001\u0000\u0000\u0000\u19e9\u19eb"+
		"\u0007m\u0000\u0000\u19ea\u19de\u0001\u0000\u0000\u0000\u19ea\u19df\u0001"+
		"\u0000\u0000\u0000\u19ea\u19e0\u0001\u0000\u0000\u0000\u19ea\u19e2\u0001"+
		"\u0000\u0000\u0000\u19ea\u19e3\u0001\u0000\u0000\u0000\u19ea\u19e4\u0001"+
		"\u0000\u0000\u0000\u19ea\u19e5\u0001\u0000\u0000\u0000\u19ea\u19e7\u0001"+
		"\u0000\u0000\u0000\u19eb\u0263\u0001\u0000\u0000\u0000\u19ec\u19ee\u0007"+
		"n\u0000\u0000\u19ed\u19ef\u0005\u00ee\u0000\u0000\u19ee\u19ed\u0001\u0000"+
		"\u0000\u0000\u19ee\u19ef\u0001\u0000\u0000\u0000\u19ef\u19f1\u0001\u0000"+
		"\u0000\u0000\u19f0\u19f2\u0003\u026c\u0136\u0000\u19f1\u19f0\u0001\u0000"+
		"\u0000\u0000\u19f1\u19f2\u0001\u0000\u0000\u0000\u19f2\u19f4\u0001\u0000"+
		"\u0000\u0000\u19f3\u19f5\u0005\u00e2\u0000\u0000\u19f4\u19f3\u0001\u0000"+
		"\u0000\u0000\u19f4\u19f5\u0001\u0000\u0000\u0000\u19f5\u19f9\u0001\u0000"+
		"\u0000\u0000\u19f6\u19f7\u0003B!\u0000\u19f7\u19f8\u0003\u023e\u011f\u0000"+
		"\u19f8\u19fa\u0001\u0000\u0000\u0000\u19f9\u19f6\u0001\u0000\u0000\u0000"+
		"\u19f9\u19fa\u0001\u0000\u0000\u0000\u19fa\u19fe\u0001\u0000\u0000\u0000"+
		"\u19fb\u19fc\u0005\u001c\u0000\u0000\u19fc\u19ff\u0003\u0240\u0120\u0000"+
		"\u19fd\u19ff\u0005\u00e2\u0000\u0000\u19fe\u19fb\u0001\u0000\u0000\u0000"+
		"\u19fe\u19fd\u0001\u0000\u0000\u0000\u19fe\u19ff\u0001\u0000\u0000\u0000"+
		"\u19ff\u1a67\u0001\u0000\u0000\u0000\u1a00\u1a01\u0005\u00e1\u0000\u0000"+
		"\u1a01\u1a03\u0007o\u0000\u0000\u1a02\u1a04\u0003\u026c\u0136\u0000\u1a03"+
		"\u1a02\u0001\u0000\u0000\u0000\u1a03\u1a04\u0001\u0000\u0000\u0000\u1a04"+
		"\u1a06\u0001\u0000\u0000\u0000\u1a05\u1a07\u0005\u00e2\u0000\u0000\u1a06"+
		"\u1a05\u0001\u0000\u0000\u0000\u1a06\u1a07\u0001\u0000\u0000\u0000\u1a07"+
		"\u1a67\u0001\u0000\u0000\u0000\u1a08\u1a09\u0005\u0207\u0000\u0000\u1a09"+
		"\u1a0b\u0005\u00df\u0000\u0000\u1a0a\u1a0c\u0003\u026c\u0136\u0000\u1a0b"+
		"\u1a0a\u0001\u0000\u0000\u0000\u1a0b\u1a0c\u0001\u0000\u0000\u0000\u1a0c"+
		"\u1a0e\u0001\u0000\u0000\u0000\u1a0d\u1a0f\u0005\u00e2\u0000\u0000\u1a0e"+
		"\u1a0d\u0001\u0000\u0000\u0000\u1a0e\u1a0f\u0001\u0000\u0000\u0000\u1a0f"+
		"\u1a67\u0001\u0000\u0000\u0000\u1a10\u1a11\u0005\u00e1\u0000\u0000\u1a11"+
		"\u1a12\u0007p\u0000\u0000\u1a12\u1a14\u0005\u00ee\u0000\u0000\u1a13\u1a15"+
		"\u0003\u026c\u0136\u0000\u1a14\u1a13\u0001\u0000\u0000\u0000\u1a14\u1a15"+
		"\u0001\u0000\u0000\u0000\u1a15\u1a17\u0001\u0000\u0000\u0000\u1a16\u1a18"+
		"\u0005\u00e2\u0000\u0000\u1a17\u1a16\u0001\u0000\u0000\u0000\u1a17\u1a18"+
		"\u0001\u0000\u0000\u0000\u1a18\u1a67\u0001\u0000\u0000\u0000\u1a19\u1a1b"+
		"\u0007q\u0000\u0000\u1a1a\u1a1c\u0003\u026c\u0136\u0000\u1a1b\u1a1a\u0001"+
		"\u0000\u0000\u0000\u1a1b\u1a1c\u0001\u0000\u0000\u0000\u1a1c\u1a20\u0001"+
		"\u0000\u0000\u0000\u1a1d\u1a1f\u0007r\u0000\u0000\u1a1e\u1a1d\u0001\u0000"+
		"\u0000\u0000\u1a1f\u1a22\u0001\u0000\u0000\u0000\u1a20\u1a1e\u0001\u0000"+
		"\u0000\u0000\u1a20\u1a21\u0001\u0000\u0000\u0000\u1a21\u1a67\u0001\u0000"+
		"\u0000\u0000\u1a22\u1a20\u0001\u0000\u0000\u0000\u1a23\u1a25\u0005\u00d0"+
		"\u0000\u0000\u1a24\u1a26\u0003\u026e\u0137\u0000\u1a25\u1a24\u0001\u0000"+
		"\u0000\u0000\u1a25\u1a26\u0001\u0000\u0000\u0000\u1a26\u1a2a\u0001\u0000"+
		"\u0000\u0000\u1a27\u1a29\u0007r\u0000\u0000\u1a28\u1a27\u0001\u0000\u0000"+
		"\u0000\u1a29\u1a2c\u0001\u0000\u0000\u0000\u1a2a\u1a28\u0001\u0000\u0000"+
		"\u0000\u1a2a\u1a2b\u0001\u0000\u0000\u0000\u1a2b\u1a67\u0001\u0000\u0000"+
		"\u0000\u1a2c\u1a2a\u0001\u0000\u0000\u0000\u1a2d\u1a2f\u0005\u00d1\u0000"+
		"\u0000\u1a2e\u1a30\u0005\u00d2\u0000\u0000\u1a2f\u1a2e\u0001\u0000\u0000"+
		"\u0000\u1a2f\u1a30\u0001\u0000\u0000\u0000\u1a30\u1a32\u0001\u0000\u0000"+
		"\u0000\u1a31\u1a33\u0003\u026e\u0137\u0000\u1a32\u1a31\u0001\u0000\u0000"+
		"\u0000\u1a32\u1a33\u0001\u0000\u0000\u0000\u1a33\u1a37\u0001\u0000\u0000"+
		"\u0000\u1a34\u1a36\u0007r\u0000\u0000\u1a35\u1a34\u0001\u0000\u0000\u0000"+
		"\u1a36\u1a39\u0001\u0000\u0000\u0000\u1a37\u1a35\u0001\u0000\u0000\u0000"+
		"\u1a37\u1a38\u0001\u0000\u0000\u0000\u1a38\u1a67\u0001\u0000\u0000\u0000"+
		"\u1a39\u1a37\u0001\u0000\u0000\u0000\u1a3a\u1a3c\u0007s\u0000\u0000\u1a3b"+
		"\u1a3d\u0003\u0270\u0138\u0000\u1a3c\u1a3b\u0001\u0000\u0000\u0000\u1a3c"+
		"\u1a3d\u0001\u0000\u0000\u0000\u1a3d\u1a41\u0001\u0000\u0000\u0000\u1a3e"+
		"\u1a40\u0007r\u0000\u0000\u1a3f\u1a3e\u0001\u0000\u0000\u0000\u1a40\u1a43"+
		"\u0001\u0000\u0000\u0000\u1a41\u1a3f\u0001\u0000\u0000\u0000\u1a41\u1a42"+
		"\u0001\u0000\u0000\u0000\u1a42\u1a67\u0001\u0000\u0000\u0000\u1a43\u1a41"+
		"\u0001\u0000\u0000\u0000\u1a44\u1a67\u0007t\u0000\u0000\u1a45\u1a47\u0007"+
		"u\u0000\u0000\u1a46\u1a48\u0003\u026c\u0136\u0000\u1a47\u1a46\u0001\u0000"+
		"\u0000\u0000\u1a47\u1a48\u0001\u0000\u0000\u0000\u1a48\u1a67\u0001\u0000"+
		"\u0000\u0000\u1a49\u1a4a\u0007v\u0000\u0000\u1a4a\u1a4c\u0003\u0266\u0133"+
		"\u0000\u1a4b\u1a4d\u0005\u00e2\u0000\u0000\u1a4c\u1a4b\u0001\u0000\u0000";
	private static final String _serializedATNSegment3 =
		"\u0000\u1a4c\u1a4d\u0001\u0000\u0000\u0000\u1a4d\u1a51\u0001\u0000\u0000"+
		"\u0000\u1a4e\u1a4f\u0003B!\u0000\u1a4f\u1a50\u0003\u023e\u011f\u0000\u1a50"+
		"\u1a52\u0001\u0000\u0000\u0000\u1a51\u1a4e\u0001\u0000\u0000\u0000\u1a51"+
		"\u1a52\u0001\u0000\u0000\u0000\u1a52\u1a67\u0001\u0000\u0000\u0000\u1a53"+
		"\u1a67\u0007w\u0000\u0000\u1a54\u1a56\u0005\u00e7\u0000\u0000\u1a55\u1a57"+
		"\u0005\u00df\u0000\u0000\u1a56\u1a55\u0001\u0000\u0000\u0000\u1a56\u1a57"+
		"\u0001\u0000\u0000\u0000\u1a57\u1a59\u0001\u0000\u0000\u0000\u1a58\u1a5a"+
		"\u0005\u00e2\u0000\u0000\u1a59\u1a58\u0001\u0000\u0000\u0000\u1a59\u1a5a"+
		"\u0001\u0000\u0000\u0000\u1a5a\u1a5e\u0001\u0000\u0000\u0000\u1a5b\u1a5c"+
		"\u0003B!\u0000\u1a5c\u1a5d\u0003\u023e\u011f\u0000\u1a5d\u1a5f\u0001\u0000"+
		"\u0000\u0000\u1a5e\u1a5b\u0001\u0000\u0000\u0000\u1a5e\u1a5f\u0001\u0000"+
		"\u0000\u0000\u1a5f\u1a62\u0001\u0000\u0000\u0000\u1a60\u1a61\u0005\u001c"+
		"\u0000\u0000\u1a61\u1a63\u0003\u0240\u0120\u0000\u1a62\u1a60\u0001\u0000"+
		"\u0000\u0000\u1a62\u1a63\u0001\u0000\u0000\u0000\u1a63\u1a67\u0001\u0000"+
		"\u0000\u0000\u1a64\u1a65\u0005\u00e7\u0000\u0000\u1a65\u1a67\u0005\u00e3"+
		"\u0000\u0000\u1a66\u19ec\u0001\u0000\u0000\u0000\u1a66\u1a00\u0001\u0000"+
		"\u0000\u0000\u1a66\u1a08\u0001\u0000\u0000\u0000\u1a66\u1a10\u0001\u0000"+
		"\u0000\u0000\u1a66\u1a19\u0001\u0000\u0000\u0000\u1a66\u1a23\u0001\u0000"+
		"\u0000\u0000\u1a66\u1a2d\u0001\u0000\u0000\u0000\u1a66\u1a3a\u0001\u0000"+
		"\u0000\u0000\u1a66\u1a44\u0001\u0000\u0000\u0000\u1a66\u1a45\u0001\u0000"+
		"\u0000\u0000\u1a66\u1a49\u0001\u0000\u0000\u0000\u1a66\u1a53\u0001\u0000"+
		"\u0000\u0000\u1a66\u1a54\u0001\u0000\u0000\u0000\u1a66\u1a64\u0001\u0000"+
		"\u0000\u0000\u1a67\u0265\u0001\u0000\u0000\u0000\u1a68\u1a69\u0005\u0482"+
		"\u0000\u0000\u1a69\u1a6e\u0003\u0268\u0134\u0000\u1a6a\u1a6b\u0005\u0484"+
		"\u0000\u0000\u1a6b\u1a6d\u0003\u0268\u0134\u0000\u1a6c\u1a6a\u0001\u0000"+
		"\u0000\u0000\u1a6d\u1a70\u0001\u0000\u0000\u0000\u1a6e\u1a6c\u0001\u0000"+
		"\u0000\u0000\u1a6e\u1a6f\u0001\u0000\u0000\u0000\u1a6f\u1a71\u0001\u0000"+
		"\u0000\u0000\u1a70\u1a6e\u0001\u0000\u0000\u0000\u1a71\u1a72\u0005\u0483"+
		"\u0000\u0000\u1a72\u0267\u0001\u0000\u0000\u0000\u1a73\u1a74\u0005\u0491"+
		"\u0000\u0000\u1a74\u0269\u0001\u0000\u0000\u0000\u1a75\u1a77\u0007x\u0000"+
		"\u0000\u1a76\u1a78\u0003\u026c\u0136\u0000\u1a77\u1a76\u0001\u0000\u0000"+
		"\u0000\u1a77\u1a78\u0001\u0000\u0000\u0000\u1a78\u1a8c\u0001\u0000\u0000"+
		"\u0000\u1a79\u1a7b\u0005\u00de\u0000\u0000\u1a7a\u1a7c\u0003\u026c\u0136"+
		"\u0000\u1a7b\u1a7a\u0001\u0000\u0000\u0000\u1a7b\u1a7c\u0001\u0000\u0000"+
		"\u0000\u1a7c\u1a80\u0001\u0000\u0000\u0000\u1a7d\u1a7e\u0003B!\u0000\u1a7e"+
		"\u1a7f\u0003\u023e\u011f\u0000\u1a7f\u1a81\u0001\u0000\u0000\u0000\u1a80"+
		"\u1a7d\u0001\u0000\u0000\u0000\u1a80\u1a81\u0001\u0000\u0000\u0000\u1a81"+
		"\u1a8c\u0001\u0000\u0000\u0000\u1a82\u1a8c\u0007y\u0000\u0000\u1a83\u1a85"+
		"\u0005\u00d6\u0000\u0000\u1a84\u1a86\u0003\u0270\u0138\u0000\u1a85\u1a84"+
		"\u0001\u0000\u0000\u0000\u1a85\u1a86\u0001\u0000\u0000\u0000\u1a86\u1a8c"+
		"\u0001\u0000\u0000\u0000\u1a87\u1a89\u0007z\u0000\u0000\u1a88\u1a8a\u0005"+
		"\u00ce\u0000\u0000\u1a89\u1a88\u0001\u0000\u0000\u0000\u1a89\u1a8a\u0001"+
		"\u0000\u0000\u0000\u1a8a\u1a8c\u0001\u0000\u0000\u0000\u1a8b\u1a75\u0001"+
		"\u0000\u0000\u0000\u1a8b\u1a79\u0001\u0000\u0000\u0000\u1a8b\u1a82\u0001"+
		"\u0000\u0000\u0000\u1a8b\u1a83\u0001\u0000\u0000\u0000\u1a8b\u1a87\u0001"+
		"\u0000\u0000\u0000\u1a8c\u1a8e\u0001\u0000\u0000\u0000\u1a8d\u1a8f\u0005"+
		"\u000b\u0000\u0000\u1a8e\u1a8d\u0001\u0000\u0000\u0000\u1a8e\u1a8f\u0001"+
		"\u0000\u0000\u0000\u1a8f\u026b\u0001\u0000\u0000\u0000\u1a90\u1a91\u0005"+
		"\u0482\u0000\u0000\u1a91\u1a92\u0003\u0256\u012b\u0000\u1a92\u1a93\u0005"+
		"\u0483\u0000\u0000\u1a93\u026d\u0001\u0000\u0000\u0000\u1a94\u1a95\u0005"+
		"\u0482\u0000\u0000\u1a95\u1a96\u0003\u0256\u012b\u0000\u1a96\u1a97\u0005"+
		"\u0484\u0000\u0000\u1a97\u1a98\u0003\u0256\u012b\u0000\u1a98\u1a99\u0005"+
		"\u0483\u0000\u0000\u1a99\u026f\u0001\u0000\u0000\u0000\u1a9a\u1a9b\u0005"+
		"\u0482\u0000\u0000\u1a9b\u1a9e\u0003\u0256\u012b\u0000\u1a9c\u1a9d\u0005"+
		"\u0484\u0000\u0000\u1a9d\u1a9f\u0003\u0256\u012b\u0000\u1a9e\u1a9c\u0001"+
		"\u0000\u0000\u0000\u1a9e\u1a9f\u0001\u0000\u0000\u0000\u1a9f\u1aa0\u0001"+
		"\u0000\u0000\u0000\u1aa0\u1aa1\u0005\u0483\u0000\u0000\u1aa1\u0271\u0001"+
		"\u0000\u0000\u0000\u1aa2\u1aa7\u0003\u0250\u0128\u0000\u1aa3\u1aa4\u0005"+
		"\u0484\u0000\u0000\u1aa4\u1aa6\u0003\u0250\u0128\u0000\u1aa5\u1aa3\u0001"+
		"\u0000\u0000\u0000\u1aa6\u1aa9\u0001\u0000\u0000\u0000\u1aa7\u1aa5\u0001"+
		"\u0000\u0000\u0000\u1aa7\u1aa8\u0001\u0000\u0000\u0000\u1aa8\u0273\u0001"+
		"\u0000\u0000\u0000\u1aa9\u1aa7\u0001\u0000\u0000\u0000\u1aaa\u1aaf\u0003"+
		"\u022e\u0117\u0000\u1aab\u1aac\u0005\u0484\u0000\u0000\u1aac\u1aae\u0003"+
		"\u022e\u0117\u0000\u1aad\u1aab\u0001\u0000\u0000\u0000\u1aae\u1ab1\u0001"+
		"\u0000\u0000\u0000\u1aaf\u1aad\u0001\u0000\u0000\u0000\u1aaf\u1ab0\u0001"+
		"\u0000\u0000\u0000\u1ab0\u0275\u0001\u0000\u0000\u0000\u1ab1\u1aaf\u0001"+
		"\u0000\u0000\u0000\u1ab2\u1ab3\u0005\u0482\u0000\u0000\u1ab3\u1ab8\u0003"+
		"\u0234\u011a\u0000\u1ab4\u1ab5\u0005\u0484\u0000\u0000\u1ab5\u1ab7\u0003"+
		"\u0234\u011a\u0000\u1ab6\u1ab4\u0001\u0000\u0000\u0000\u1ab7\u1aba\u0001"+
		"\u0000\u0000\u0000\u1ab8\u1ab6\u0001\u0000\u0000\u0000\u1ab8\u1ab9\u0001"+
		"\u0000\u0000\u0000\u1ab9\u1abb\u0001\u0000\u0000\u0000\u1aba\u1ab8\u0001"+
		"\u0000\u0000\u0000\u1abb\u1abc\u0005\u0483\u0000\u0000\u1abc\u0277\u0001"+
		"\u0000\u0000\u0000\u1abd\u1ac2\u0003\u02ba\u015d\u0000\u1abe\u1abf\u0005"+
		"\u0484\u0000\u0000\u1abf\u1ac1\u0003\u02ba\u015d\u0000\u1ac0\u1abe\u0001"+
		"\u0000\u0000\u0000\u1ac1\u1ac4\u0001\u0000\u0000\u0000\u1ac2\u1ac0\u0001"+
		"\u0000\u0000\u0000\u1ac2\u1ac3\u0001\u0000\u0000\u0000\u1ac3\u0279\u0001"+
		"\u0000\u0000\u0000\u1ac4\u1ac2\u0001\u0000\u0000\u0000\u1ac5\u1aca\u0003"+
		"\u0286\u0143\u0000\u1ac6\u1ac7\u0005\u0484\u0000\u0000\u1ac7\u1ac9\u0003"+
		"\u0286\u0143\u0000\u1ac8\u1ac6\u0001\u0000\u0000\u0000\u1ac9\u1acc\u0001"+
		"\u0000\u0000\u0000\u1aca\u1ac8\u0001\u0000\u0000\u0000\u1aca\u1acb\u0001"+
		"\u0000\u0000\u0000\u1acb\u027b\u0001\u0000\u0000\u0000\u1acc\u1aca\u0001"+
		"\u0000\u0000\u0000\u1acd\u1ad2\u0003\u0262\u0131\u0000\u1ace\u1acf\u0005"+
		"\u0484\u0000\u0000\u1acf\u1ad1\u0003\u0262\u0131\u0000\u1ad0\u1ace\u0001"+
		"\u0000\u0000\u0000\u1ad1\u1ad4\u0001\u0000\u0000\u0000\u1ad2\u1ad0\u0001"+
		"\u0000\u0000\u0000\u1ad2\u1ad3\u0001\u0000\u0000\u0000\u1ad3\u027d\u0001"+
		"\u0000\u0000\u0000\u1ad4\u1ad2\u0001\u0000\u0000\u0000\u1ad5\u1ada\u0005"+
		"\u0491\u0000\u0000\u1ad6\u1ad7\u0005\u0484\u0000\u0000\u1ad7\u1ad9\u0005"+
		"\u0491\u0000\u0000\u1ad8\u1ad6\u0001\u0000\u0000\u0000\u1ad9\u1adc\u0001"+
		"\u0000\u0000\u0000\u1ada\u1ad8\u0001\u0000\u0000\u0000\u1ada\u1adb\u0001"+
		"\u0000\u0000\u0000\u1adb\u027f\u0001\u0000\u0000\u0000\u1adc\u1ada\u0001"+
		"\u0000\u0000\u0000\u1add\u1ae2\u0005\u049c\u0000\u0000\u1ade\u1adf\u0005"+
		"\u0484\u0000\u0000\u1adf\u1ae1\u0005\u049c\u0000\u0000\u1ae0\u1ade\u0001"+
		"\u0000\u0000\u0000\u1ae1\u1ae4\u0001\u0000\u0000\u0000\u1ae2\u1ae0\u0001"+
		"\u0000\u0000\u0000\u1ae2\u1ae3\u0001\u0000\u0000\u0000\u1ae3\u0281\u0001"+
		"\u0000\u0000\u0000\u1ae4\u1ae2\u0001\u0000\u0000\u0000\u1ae5\u1b09\u0005"+
		"t\u0000\u0000\u1ae6\u1ae7\u0005\u0018\u0000\u0000\u1ae7\u1ae8\u0005\u0482"+
		"\u0000\u0000\u1ae8\u1ae9\u0003\u02ba\u015d\u0000\u1ae9\u1aea\u0005\f\u0000"+
		"\u0000\u1aea\u1aeb\u0003\u026a\u0135\u0000\u1aeb\u1aec\u0005\u0483\u0000"+
		"\u0000\u1aec\u1b09\u0001\u0000\u0000\u0000\u1aed\u1aef\u0003\u02c0\u0160"+
		"\u0000\u1aee\u1aed\u0001\u0000\u0000\u0000\u1aee\u1aef\u0001\u0000\u0000"+
		"\u0000\u1aef\u1af0\u0001\u0000\u0000\u0000\u1af0\u1b09\u0003\u0262\u0131"+
		"\u0000\u1af1\u1af5\u0003\u0284\u0142\u0000\u1af2\u1af3\u0005v\u0000\u0000"+
		"\u1af3\u1af4\u0005\u00b8\u0000\u0000\u1af4\u1af6\u0003\u0284\u0142\u0000"+
		"\u1af5\u1af2\u0001\u0000\u0000\u0000\u1af5\u1af6\u0001\u0000\u0000\u0000"+
		"\u1af6\u1b09\u0001\u0000\u0000\u0000\u1af7\u1af8\u0005\u0482\u0000\u0000"+
		"\u1af8\u1af9\u0003\u02ba\u015d\u0000\u1af9\u1afa\u0005\u0483\u0000\u0000"+
		"\u1afa\u1b09\u0001\u0000\u0000\u0000\u1afb\u1afc\u0007{\u0000\u0000\u1afc"+
		"\u1afd\u0005\u0482\u0000\u0000\u1afd\u1afe\u0003\u022c\u0116\u0000\u1afe"+
		"\u1aff\u0005\u0483\u0000\u0000\u1aff\u1b09\u0001\u0000\u0000\u0000\u1b00"+
		"\u1b01\u0005\u0482\u0000\u0000\u1b01\u1b02\u0007|\u0000\u0000\u1b02\u1b03"+
		"\u0005\u02a1\u0000\u0000\u1b03\u1b04\u0005A\u0000\u0000\u1b04\u1b05\u0003"+
		"\u022c\u0116\u0000\u1b05\u1b06\u0005\u0483\u0000\u0000\u1b06\u1b09\u0001"+
		"\u0000\u0000\u0000\u1b07\u1b09\u0003\u02ba\u015d\u0000\u1b08\u1ae5\u0001"+
		"\u0000\u0000\u0000\u1b08\u1ae6\u0001\u0000\u0000\u0000\u1b08\u1aee\u0001"+
		"\u0000\u0000\u0000\u1b08\u1af1\u0001\u0000\u0000\u0000\u1b08\u1af7\u0001"+
		"\u0000\u0000\u0000\u1b08\u1afb\u0001\u0000\u0000\u0000\u1b08\u1b00\u0001"+
		"\u0000\u0000\u0000\u1b08\u1b07\u0001\u0000\u0000\u0000\u1b09\u0283\u0001"+
		"\u0000\u0000\u0000\u1b0a\u1b10\u0007}\u0000\u0000\u1b0b\u1b0d\u0005\u0482"+
		"\u0000\u0000\u1b0c\u1b0e\u0003\u0256\u012b\u0000\u1b0d\u1b0c\u0001\u0000"+
		"\u0000\u0000\u1b0d\u1b0e\u0001\u0000\u0000\u0000\u1b0e\u1b0f\u0001\u0000"+
		"\u0000\u0000\u1b0f\u1b11\u0005\u0483\u0000\u0000\u1b10\u1b0b\u0001\u0000"+
		"\u0000\u0000\u1b10\u1b11\u0001\u0000\u0000\u0000\u1b11\u1b19\u0001\u0000"+
		"\u0000\u0000\u1b12\u1b13\u0005\u0143\u0000\u0000\u1b13\u1b15\u0005\u0482"+
		"\u0000\u0000\u1b14\u1b16\u0003\u0256\u012b\u0000\u1b15\u1b14\u0001\u0000"+
		"\u0000\u0000\u1b15\u1b16\u0001\u0000\u0000\u0000\u1b16\u1b17\u0001\u0000"+
		"\u0000\u0000\u1b17\u1b19\u0005\u0483\u0000\u0000\u1b18\u1b0a\u0001\u0000"+
		"\u0000\u0000\u1b18\u1b12\u0001\u0000\u0000\u0000\u1b19\u0285\u0001\u0000"+
		"\u0000\u0000\u1b1a\u1b1d\u0003\u02ba\u015d\u0000\u1b1b\u1b1d\u0005+\u0000"+
		"\u0000\u1b1c\u1b1a\u0001\u0000\u0000\u0000\u1b1c\u1b1b\u0001\u0000\u0000"+
		"\u0000\u1b1d\u0287\u0001\u0000\u0000\u0000\u1b1e\u1b1f\u0005M\u0000\u0000"+
		"\u1b1f\u1b20\u0005<\u0000\u0000\u1b20\u0289\u0001\u0000\u0000\u0000\u1b21"+
		"\u1b22\u0005M\u0000\u0000\u1b22\u1b23\u0005r\u0000\u0000\u1b23\u1b24\u0005"+
		"<\u0000\u0000\u1b24\u028b\u0001\u0000\u0000\u0000\u1b25\u1b26\u0005{\u0000"+
		"\u0000\u1b26\u1b27\u0005\u008e\u0000\u0000\u1b27\u028d\u0001\u0000\u0000"+
		"\u0000\u1b28\u1b29\u0005\u02a6\u0000\u0000\u1b29\u1b2c\u0003\u0256\u012b"+
		"\u0000\u1b2a\u1b2c\u0005\u0210\u0000\u0000\u1b2b\u1b28\u0001\u0000\u0000"+
		"\u0000\u1b2b\u1b2a\u0001\u0000\u0000\u0000\u1b2c\u028f\u0001\u0000\u0000"+
		"\u0000\u1b2d\u1b31\u0003\u028e\u0147\u0000\u1b2e\u1b2f\u0005\u009e\u0000"+
		"\u0000\u1b2f\u1b31\u0005h\u0000\u0000\u1b30\u1b2d\u0001\u0000\u0000\u0000"+
		"\u1b30\u1b2e\u0001\u0000\u0000\u0000\u1b31\u0291\u0001\u0000\u0000\u0000"+
		"\u1b32\u1b45\u0003\u0294\u014a\u0000\u1b33\u1b45\u0003\u029c\u014e\u0000"+
		"\u1b34\u1b45\u0003\u029e\u014f\u0000\u1b35\u1b36\u0003\u02b2\u0159\u0000"+
		"\u1b36\u1b38\u0005\u0482\u0000\u0000\u1b37\u1b39\u0003\u02b6\u015b\u0000"+
		"\u1b38\u1b37\u0001\u0000\u0000\u0000\u1b38\u1b39\u0001\u0000\u0000\u0000"+
		"\u1b39\u1b3a\u0001\u0000\u0000\u0000\u1b3a\u1b3b\u0005\u0483\u0000\u0000"+
		"\u1b3b\u1b45\u0001\u0000\u0000\u0000\u1b3c\u1b3d\u0003\u022c\u0116\u0000"+
		"\u1b3d\u1b3f\u0005\u0482\u0000\u0000\u1b3e\u1b40\u0003\u02b6\u015b\u0000"+
		"\u1b3f\u1b3e\u0001\u0000\u0000\u0000\u1b3f\u1b40\u0001\u0000\u0000\u0000"+
		"\u1b40\u1b41\u0001\u0000\u0000\u0000\u1b41\u1b42\u0005\u0483\u0000\u0000"+
		"\u1b42\u1b45\u0001\u0000\u0000\u0000\u1b43\u1b45\u0003\u02b4\u015a\u0000"+
		"\u1b44\u1b32\u0001\u0000\u0000\u0000\u1b44\u1b33\u0001\u0000\u0000\u0000"+
		"\u1b44\u1b34\u0001\u0000\u0000\u0000\u1b44\u1b35\u0001\u0000\u0000\u0000"+
		"\u1b44\u1b3c\u0001\u0000\u0000\u0000\u1b44\u1b43\u0001\u0000\u0000\u0000"+
		"\u1b45\u0293\u0001\u0000\u0000\u0000\u1b46\u1b49\u0007~\u0000\u0000\u1b47"+
		"\u1b48\u0005\u0482\u0000\u0000\u1b48\u1b4a\u0005\u0483\u0000\u0000\u1b49"+
		"\u1b47\u0001\u0000\u0000\u0000\u1b49\u1b4a\u0001\u0000\u0000\u0000\u1b4a"+
		"\u1bf9\u0001\u0000\u0000\u0000\u1b4b\u1b4c\u0005!\u0000\u0000\u1b4c\u1b4d"+
		"\u0005\u0482\u0000\u0000\u1b4d\u1b4e\u0003\u02ba\u015d\u0000\u1b4e\u1b4f"+
		"\u0005\u0484\u0000\u0000\u1b4f\u1b50\u0003\u026a\u0135\u0000\u1b50\u1b51"+
		"\u0005\u0483\u0000\u0000\u1b51\u1bf9\u0001\u0000\u0000\u0000\u1b52\u1b53"+
		"\u0005!\u0000\u0000\u1b53\u1b54\u0005\u0482\u0000\u0000\u1b54\u1b55\u0003"+
		"\u02ba\u015d\u0000\u1b55\u1b56\u0005\u00bb\u0000\u0000\u1b56\u1b57\u0003"+
		"\u023e\u011f\u0000\u1b57\u1b58\u0005\u0483\u0000\u0000\u1b58\u1bf9\u0001"+
		"\u0000\u0000\u0000\u1b59\u1b5a\u0005\u0018\u0000\u0000\u1b5a\u1b5b\u0005"+
		"\u0482\u0000\u0000\u1b5b\u1b5c\u0003\u02ba\u015d\u0000\u1b5c\u1b5d\u0005"+
		"\f\u0000\u0000\u1b5d\u1b5e\u0003\u026a\u0135\u0000\u1b5e\u1b5f\u0005\u0483"+
		"\u0000\u0000\u1b5f\u1bf9\u0001\u0000\u0000\u0000\u1b60\u1b61\u0005\u00bc"+
		"\u0000\u0000\u1b61\u1b62\u0005\u0482\u0000\u0000\u1b62\u1b63\u0003\u0232"+
		"\u0119\u0000\u1b63\u1b64\u0005\u0483\u0000\u0000\u1b64\u1bf9\u0001\u0000"+
		"\u0000\u0000\u1b65\u1b66\u0005\u0017\u0000\u0000\u1b66\u1b68\u0003\u02ba"+
		"\u015d\u0000\u1b67\u1b69\u0003\u0296\u014b\u0000\u1b68\u1b67\u0001\u0000"+
		"\u0000\u0000\u1b69\u1b6a\u0001\u0000\u0000\u0000\u1b6a\u1b68\u0001\u0000"+
		"\u0000\u0000\u1b6a\u1b6b\u0001\u0000\u0000\u0000\u1b6b\u1b6e\u0001\u0000"+
		"\u0000\u0000\u1b6c\u1b6d\u00056\u0000\u0000\u1b6d\u1b6f\u0003\u02b8\u015c"+
		"\u0000\u1b6e\u1b6c\u0001\u0000\u0000\u0000\u1b6e\u1b6f\u0001\u0000\u0000"+
		"\u0000\u1b6f\u1b70\u0001\u0000\u0000\u0000\u1b70\u1b71\u0005\u0197\u0000"+
		"\u0000\u1b71\u1bf9\u0001\u0000\u0000\u0000\u1b72\u1b74\u0005\u0017\u0000"+
		"\u0000\u1b73\u1b75\u0003\u0296\u014b\u0000\u1b74\u1b73\u0001\u0000\u0000"+
		"\u0000\u1b75\u1b76\u0001\u0000\u0000\u0000\u1b76\u1b74\u0001\u0000\u0000"+
		"\u0000\u1b76\u1b77\u0001\u0000\u0000\u0000\u1b77\u1b7a\u0001\u0000\u0000"+
		"\u0000\u1b78\u1b79\u00056\u0000\u0000\u1b79\u1b7b\u0003\u02b8\u015c\u0000"+
		"\u1b7a\u1b78\u0001\u0000\u0000\u0000\u1b7a\u1b7b\u0001\u0000\u0000\u0000"+
		"\u1b7b\u1b7c\u0001\u0000\u0000\u0000\u1b7c\u1b7d\u0005\u0197\u0000\u0000"+
		"\u1b7d\u1bf9\u0001\u0000\u0000\u0000\u1b7e\u1b7f\u0005\u00de\u0000\u0000"+
		"\u1b7f\u1b80\u0005\u0482\u0000\u0000\u1b80\u1b83\u0003\u02b6\u015b\u0000"+
		"\u1b81\u1b82\u0005\u00bb\u0000\u0000\u1b82\u1b84\u0003\u023e\u011f\u0000"+
		"\u1b83\u1b81\u0001\u0000\u0000\u0000\u1b83\u1b84\u0001\u0000\u0000\u0000"+
		"\u1b84\u1b85\u0001\u0000\u0000\u0000\u1b85\u1b86\u0005\u0483\u0000\u0000"+
		"\u1b86\u1bf9\u0001\u0000\u0000\u0000\u1b87\u1b88\u0005\u0144\u0000\u0000"+
		"\u1b88\u1b8b\u0005\u0482\u0000\u0000\u1b89\u1b8c\u0003\u025a\u012d\u0000"+
		"\u1b8a\u1b8c\u0003\u02ba\u015d\u0000\u1b8b\u1b89\u0001\u0000\u0000\u0000"+
		"\u1b8b\u1b8a\u0001\u0000\u0000\u0000\u1b8c\u1b8d\u0001\u0000\u0000\u0000"+
		"\u1b8d\u1b90\u0005P\u0000\u0000\u1b8e\u1b91\u0003\u025a\u012d\u0000\u1b8f"+
		"\u1b91\u0003\u02ba\u015d\u0000\u1b90\u1b8e\u0001\u0000\u0000\u0000\u1b90"+
		"\u1b8f\u0001\u0000\u0000\u0000\u1b91\u1b92\u0001\u0000\u0000\u0000\u1b92"+
		"\u1b93\u0005\u0483\u0000\u0000\u1b93\u1bf9\u0001\u0000\u0000\u0000\u1b94"+
		"\u1b95\u0007\u007f\u0000\u0000\u1b95\u1b98\u0005\u0482\u0000\u0000\u1b96"+
		"\u1b99\u0003\u025a\u012d\u0000\u1b97\u1b99\u0003\u02ba\u015d\u0000\u1b98"+
		"\u1b96\u0001\u0000\u0000\u0000\u1b98\u1b97\u0001\u0000\u0000\u0000\u1b99"+
		"\u1b9a\u0001\u0000\u0000\u0000\u1b9a\u1b9d\u0005D\u0000\u0000\u1b9b\u1b9e"+
		"\u0003\u0256\u012b\u0000\u1b9c\u1b9e\u0003\u02ba\u015d\u0000\u1b9d\u1b9b"+
		"\u0001\u0000\u0000\u0000\u1b9d\u1b9c\u0001\u0000\u0000\u0000\u1b9e\u1ba4"+
		"\u0001\u0000\u0000\u0000\u1b9f\u1ba2\u0005A\u0000\u0000\u1ba0\u1ba3\u0003"+
		"\u0256\u012b\u0000\u1ba1\u1ba3\u0003\u02ba\u015d\u0000\u1ba2\u1ba0\u0001"+
		"\u0000\u0000\u0000\u1ba2\u1ba1\u0001\u0000\u0000\u0000\u1ba3\u1ba5\u0001"+
		"\u0000\u0000\u0000\u1ba4\u1b9f\u0001\u0000\u0000\u0000\u1ba4\u1ba5\u0001"+
		"\u0000\u0000\u0000\u1ba5\u1ba6\u0001\u0000\u0000\u0000\u1ba6\u1ba7\u0005"+
		"\u0483\u0000\u0000\u1ba7\u1bf9\u0001\u0000\u0000\u0000\u1ba8\u1ba9\u0005"+
		"\u0148\u0000\u0000\u1ba9\u1baa\u0005\u0482\u0000\u0000\u1baa\u1bad\u0007"+
		"\u0080\u0000\u0000\u1bab\u1bae\u0003\u025a\u012d\u0000\u1bac\u1bae\u0003"+
		"\u02ba\u015d\u0000\u1bad\u1bab\u0001\u0000\u0000\u0000\u1bad\u1bac\u0001"+
		"\u0000\u0000\u0000\u1bad\u1bae\u0001\u0000\u0000\u0000\u1bae\u1baf\u0001"+
		"\u0000\u0000\u0000\u1baf\u1bb2\u0005D\u0000\u0000\u1bb0\u1bb3\u0003\u025a"+
		"\u012d\u0000\u1bb1\u1bb3\u0003\u02ba\u015d\u0000\u1bb2\u1bb0\u0001\u0000"+
		"\u0000\u0000\u1bb2\u1bb1\u0001\u0000\u0000\u0000\u1bb3\u1bb4\u0001\u0000"+
		"\u0000\u0000\u1bb4\u1bb5\u0005\u0483\u0000\u0000\u1bb5\u1bf9\u0001\u0000"+
		"\u0000\u0000\u1bb6\u1bb7\u0005\u0148\u0000\u0000\u1bb7\u1bba\u0005\u0482"+
		"\u0000\u0000\u1bb8\u1bbb\u0003\u025a\u012d\u0000\u1bb9\u1bbb\u0003\u02ba"+
		"\u015d\u0000\u1bba\u1bb8\u0001\u0000\u0000\u0000\u1bba\u1bb9\u0001\u0000"+
		"\u0000\u0000\u1bbb\u1bbc\u0001\u0000\u0000\u0000\u1bbc\u1bbf\u0005D\u0000"+
		"\u0000\u1bbd\u1bc0\u0003\u025a\u012d\u0000\u1bbe\u1bc0\u0003\u02ba\u015d"+
		"\u0000\u1bbf\u1bbd\u0001\u0000\u0000\u0000\u1bbf\u1bbe\u0001\u0000\u0000"+
		"\u0000\u1bc0\u1bc1\u0001\u0000\u0000\u0000\u1bc1\u1bc2\u0005\u0483\u0000"+
		"\u0000\u1bc2\u1bf9\u0001\u0000\u0000\u0000\u1bc3\u1bc4\u0005\u0454\u0000"+
		"\u0000\u1bc4\u1bc7\u0005\u0482\u0000\u0000\u1bc5\u1bc8\u0003\u025a\u012d"+
		"\u0000\u1bc6\u1bc8\u0003\u02ba\u015d\u0000\u1bc7\u1bc5\u0001\u0000\u0000"+
		"\u0000\u1bc7\u1bc6\u0001\u0000\u0000\u0000\u1bc8\u1bcf\u0001\u0000\u0000"+
		"\u0000\u1bc9\u1bca\u0005\f\u0000\u0000\u1bca\u1bcb\u0007\u0081\u0000\u0000"+
		"\u1bcb\u1bcc\u0005\u0482\u0000\u0000\u1bcc\u1bcd\u0003\u0256\u012b\u0000"+
		"\u1bcd\u1bce\u0005\u0483\u0000\u0000\u1bce\u1bd0\u0001\u0000\u0000\u0000"+
		"\u1bcf\u1bc9\u0001\u0000\u0000\u0000\u1bcf\u1bd0\u0001\u0000\u0000\u0000"+
		"\u1bd0\u1bd2\u0001\u0000\u0000\u0000\u1bd1\u1bd3\u0003\u0298\u014c\u0000"+
		"\u1bd2\u1bd1\u0001\u0000\u0000\u0000\u1bd2\u1bd3\u0001\u0000\u0000\u0000"+
		"\u1bd3\u1bd4\u0001\u0000\u0000\u0000\u1bd4\u1bd5\u0005\u0483\u0000\u0000"+
		"\u1bd5\u1bf9\u0001\u0000\u0000\u0000\u1bd6\u1bd7\u0005\u0141\u0000\u0000"+
		"\u1bd7\u1bd8\u0005\u0482\u0000\u0000\u1bd8\u1bd9\u0003N\'\u0000\u1bd9"+
		"\u1bdc\u0005D\u0000\u0000\u1bda\u1bdd\u0003\u025a\u012d\u0000\u1bdb\u1bdd"+
		"\u0003\u02ba\u015d\u0000\u1bdc\u1bda\u0001\u0000\u0000\u0000\u1bdc\u1bdb"+
		"\u0001\u0000\u0000\u0000\u1bdd\u1bde\u0001\u0000\u0000\u0000\u1bde\u1bdf"+
		"\u0005\u0483\u0000\u0000\u1bdf\u1bf9\u0001\u0000\u0000\u0000\u1be0\u1be1"+
		"\u0005\u038b\u0000\u0000\u1be1\u1be2\u0005\u0482\u0000\u0000\u1be2\u1be3"+
		"\u0007\u0082\u0000\u0000\u1be3\u1be4\u0005\u0484\u0000\u0000\u1be4\u1be5"+
		"\u0003\u025a\u012d\u0000\u1be5\u1be6\u0005\u0483\u0000\u0000\u1be6\u1bf9"+
		"\u0001\u0000\u0000\u0000\u1be7\u1be8\u0005\u011a\u0000\u0000\u1be8\u1be9"+
		"\u0005\u0482\u0000\u0000\u1be9\u1bea\u0003\u02ba\u015d\u0000\u1bea\u1beb"+
		"\u0005\u0484\u0000\u0000\u1beb\u1bee\u0003\u02ba\u015d\u0000\u1bec\u1bed"+
		"\u0005\u0253\u0000\u0000\u1bed\u1bef\u0003\u026a\u0135\u0000\u1bee\u1bec"+
		"\u0001\u0000\u0000\u0000\u1bee\u1bef\u0001\u0000\u0000\u0000\u1bef\u1bf1"+
		"\u0001\u0000\u0000\u0000\u1bf0\u1bf2\u0003\u0114\u008a\u0000\u1bf1\u1bf0"+
		"\u0001\u0000\u0000\u0000\u1bf1\u1bf2\u0001\u0000\u0000\u0000\u1bf2\u1bf4"+
		"\u0001\u0000\u0000\u0000\u1bf3\u1bf5\u0003\u0116\u008b\u0000\u1bf4\u1bf3"+
		"\u0001\u0000\u0000\u0000\u1bf4\u1bf5\u0001\u0000\u0000\u0000\u1bf5\u1bf6"+
		"\u0001\u0000\u0000\u0000\u1bf6\u1bf7\u0005\u0483\u0000\u0000\u1bf7\u1bf9"+
		"\u0001\u0000\u0000\u0000\u1bf8\u1b46\u0001\u0000\u0000\u0000\u1bf8\u1b4b"+
		"\u0001\u0000\u0000\u0000\u1bf8\u1b52\u0001\u0000\u0000\u0000\u1bf8\u1b59"+
		"\u0001\u0000\u0000\u0000\u1bf8\u1b60\u0001\u0000\u0000\u0000\u1bf8\u1b65"+
		"\u0001\u0000\u0000\u0000\u1bf8\u1b72\u0001\u0000\u0000\u0000\u1bf8\u1b7e"+
		"\u0001\u0000\u0000\u0000\u1bf8\u1b87\u0001\u0000\u0000\u0000\u1bf8\u1b94"+
		"\u0001\u0000\u0000\u0000\u1bf8\u1ba8\u0001\u0000\u0000\u0000\u1bf8\u1bb6"+
		"\u0001\u0000\u0000\u0000\u1bf8\u1bc3\u0001\u0000\u0000\u0000\u1bf8\u1bd6"+
		"\u0001\u0000\u0000\u0000\u1bf8\u1be0\u0001\u0000\u0000\u0000\u1bf8\u1be7"+
		"\u0001\u0000\u0000\u0000\u1bf9\u0295\u0001\u0000\u0000\u0000\u1bfa\u1bfb"+
		"\u0005\u00bd\u0000\u0000\u1bfb\u1bfc\u0003\u02b8\u015c\u0000\u1bfc\u1bfd"+
		"\u0005\u00ae\u0000\u0000\u1bfd\u1bfe\u0003\u02b8\u015c\u0000\u1bfe\u0297"+
		"\u0001\u0000\u0000\u0000\u1bff\u1c00\u0005\u01d8\u0000\u0000\u1c00\u1c05"+
		"\u0003\u029a\u014d\u0000\u1c01\u1c02\u0005\u0484\u0000\u0000\u1c02\u1c04"+
		"\u0003\u029a\u014d\u0000\u1c03\u1c01\u0001\u0000\u0000\u0000\u1c04\u1c07"+
		"\u0001\u0000\u0000\u0000\u1c05\u1c03\u0001\u0000\u0000\u0000\u1c05\u1c06"+
		"\u0001\u0000\u0000\u0000\u1c06\u1c0e\u0001\u0000\u0000\u0000\u1c07\u1c05"+
		"\u0001\u0000\u0000\u0000\u1c08\u1c09\u0005\u01d8\u0000\u0000\u1c09\u1c0a"+
		"\u0003\u0256\u012b\u0000\u1c0a\u1c0b\u0005\u0476\u0000\u0000\u1c0b\u1c0c"+
		"\u0003\u0256\u012b\u0000\u1c0c\u1c0e\u0001\u0000\u0000\u0000\u1c0d\u1bff"+
		"\u0001\u0000\u0000\u0000\u1c0d\u1c08\u0001\u0000\u0000\u0000\u1c0e\u0299"+
		"\u0001\u0000\u0000\u0000\u1c0f\u1c11\u0003\u0256\u012b\u0000\u1c10\u1c12"+
		"\u0007\u0083\u0000\u0000\u1c11\u1c10\u0001\u0000\u0000\u0000\u1c11\u1c12"+
		"\u0001\u0000\u0000\u0000\u1c12\u029b\u0001\u0000\u0000\u0000\u1c13\u1c14"+
		"\u0007\u0084\u0000\u0000\u1c14\u1c16\u0005\u0482\u0000\u0000\u1c15\u1c17"+
		"\u0007/\u0000\u0000\u1c16\u1c15\u0001\u0000\u0000\u0000\u1c16\u1c17\u0001"+
		"\u0000\u0000\u0000\u1c17\u1c18\u0001\u0000\u0000\u0000\u1c18\u1c19\u0003"+
		"\u02b8\u015c\u0000\u1c19\u1c1b\u0005\u0483\u0000\u0000\u1c1a\u1c1c\u0003"+
		"\u02a0\u0150\u0000\u1c1b\u1c1a\u0001\u0000\u0000\u0000\u1c1b\u1c1c\u0001"+
		"\u0000\u0000\u0000\u1c1c\u1c4f\u0001\u0000\u0000\u0000\u1c1d\u1c1e\u0005"+
		"\u0122\u0000\u0000\u1c1e\u1c26\u0005\u0482\u0000\u0000\u1c1f\u1c27\u0005"+
		"\u0472\u0000\u0000\u1c20\u1c22\u0005\u0006\u0000\u0000\u1c21\u1c20\u0001"+
		"\u0000\u0000\u0000\u1c21\u1c22\u0001\u0000\u0000\u0000\u1c22\u1c23\u0001"+
		"\u0000\u0000\u0000\u1c23\u1c27\u0003\u02b8\u015c\u0000\u1c24\u1c25\u0005"+
		"2\u0000\u0000\u1c25\u1c27\u0003\u02b6\u015b\u0000\u1c26\u1c1f\u0001\u0000"+
		"\u0000\u0000\u1c26\u1c21\u0001\u0000\u0000\u0000\u1c26\u1c24\u0001\u0000"+
		"\u0000\u0000\u1c27\u1c28\u0001\u0000\u0000\u0000\u1c28\u1c2a\u0005\u0483"+
		"\u0000\u0000\u1c29\u1c2b\u0003\u02a0\u0150\u0000\u1c2a\u1c29\u0001\u0000"+
		"\u0000\u0000\u1c2a\u1c2b\u0001\u0000\u0000\u0000\u1c2b\u1c4f\u0001\u0000"+
		"\u0000\u0000\u1c2c\u1c2d\u0007\u0085\u0000\u0000\u1c2d\u1c2f\u0005\u0482"+
		"\u0000\u0000\u1c2e\u1c30\u0005\u0006\u0000\u0000\u1c2f\u1c2e\u0001\u0000"+
		"\u0000\u0000\u1c2f\u1c30\u0001\u0000\u0000\u0000\u1c30\u1c31\u0001\u0000"+
		"\u0000\u0000\u1c31\u1c32\u0003\u02b8\u015c\u0000\u1c32\u1c34\u0005\u0483"+
		"\u0000\u0000\u1c33\u1c35\u0003\u02a0\u0150\u0000\u1c34\u1c33\u0001\u0000"+
		"\u0000\u0000\u1c34\u1c35\u0001\u0000\u0000\u0000\u1c35\u1c4f\u0001\u0000"+
		"\u0000\u0000\u1c36\u1c37\u0005\u0126\u0000\u0000\u1c37\u1c39\u0005\u0482"+
		"\u0000\u0000\u1c38\u1c3a\u00052\u0000\u0000\u1c39\u1c38\u0001\u0000\u0000"+
		"\u0000\u1c39\u1c3a\u0001\u0000\u0000\u0000\u1c3a\u1c3b\u0001\u0000\u0000"+
		"\u0000\u1c3b\u1c46\u0003\u02b6\u015b\u0000\u1c3c\u1c3d\u0005|\u0000\u0000"+
		"\u1c3d\u1c3e\u0005\u0014\u0000\u0000\u1c3e\u1c43\u0003\u00f2y\u0000\u1c3f"+
		"\u1c40\u0005\u0484\u0000\u0000\u1c40\u1c42\u0003\u00f2y\u0000\u1c41\u1c3f"+
		"\u0001\u0000\u0000\u0000\u1c42\u1c45\u0001\u0000\u0000\u0000\u1c43\u1c41"+
		"\u0001\u0000\u0000\u0000\u1c43\u1c44\u0001\u0000\u0000\u0000\u1c44\u1c47"+
		"\u0001\u0000\u0000\u0000\u1c45\u1c43\u0001\u0000\u0000\u0000\u1c46\u1c3c"+
		"\u0001\u0000\u0000\u0000\u1c46\u1c47\u0001\u0000\u0000\u0000\u1c47\u1c4a"+
		"\u0001\u0000\u0000\u0000\u1c48\u1c49\u0005\u009b\u0000\u0000\u1c49\u1c4b"+
		"\u0005\u0491\u0000\u0000\u1c4a\u1c48\u0001\u0000\u0000\u0000\u1c4a\u1c4b"+
		"\u0001\u0000\u0000\u0000\u1c4b\u1c4c\u0001\u0000\u0000\u0000\u1c4c\u1c4d"+
		"\u0005\u0483\u0000\u0000\u1c4d\u1c4f\u0001\u0000\u0000\u0000\u1c4e\u1c13"+
		"\u0001\u0000\u0000\u0000\u1c4e\u1c1d\u0001\u0000\u0000\u0000\u1c4e\u1c2c"+
		"\u0001\u0000\u0000\u0000\u1c4e\u1c36\u0001\u0000\u0000\u0000\u1c4f\u029d"+
		"\u0001\u0000\u0000\u0000\u1c50\u1c51\u0007\u0086\u0000\u0000\u1c51\u1c52"+
		"\u0005\u0482\u0000\u0000\u1c52\u1c55\u0003\u02ba\u015d\u0000\u1c53\u1c54"+
		"\u0005\u0484\u0000\u0000\u1c54\u1c56\u0003\u0256\u012b\u0000\u1c55\u1c53"+
		"\u0001\u0000\u0000\u0000\u1c55\u1c56\u0001\u0000\u0000\u0000\u1c56\u1c59"+
		"\u0001\u0000\u0000\u0000\u1c57\u1c58\u0005\u0484\u0000\u0000\u1c58\u1c5a"+
		"\u0003\u0256\u012b\u0000\u1c59\u1c57\u0001\u0000\u0000\u0000\u1c59\u1c5a"+
		"\u0001\u0000\u0000\u0000\u1c5a\u1c5b\u0001\u0000\u0000\u0000\u1c5b\u1c5c"+
		"\u0005\u0483\u0000\u0000\u1c5c\u1c5d\u0003\u02a0\u0150\u0000\u1c5d\u1c77"+
		"\u0001\u0000\u0000\u0000\u1c5e\u1c5f\u0007\u0087\u0000\u0000\u1c5f\u1c60"+
		"\u0005\u0482\u0000\u0000\u1c60\u1c61\u0003\u02ba\u015d\u0000\u1c61\u1c62"+
		"\u0005\u0483\u0000\u0000\u1c62\u1c63\u0003\u02a0\u0150\u0000\u1c63\u1c77"+
		"\u0001\u0000\u0000\u0000\u1c64\u1c65\u0007\u0088\u0000\u0000\u1c65\u1c66"+
		"\u0005\u0482\u0000\u0000\u1c66\u1c67\u0005\u0483\u0000\u0000\u1c67\u1c77"+
		"\u0003\u02a0\u0150\u0000\u1c68\u1c69\u0005\u012d\u0000\u0000\u1c69\u1c6a"+
		"\u0005\u0482\u0000\u0000\u1c6a\u1c6b\u0003\u02ba\u015d\u0000\u1c6b\u1c6c"+
		"\u0005\u0484\u0000\u0000\u1c6c\u1c6d\u0003\u0256\u012b\u0000\u1c6d\u1c6e"+
		"\u0005\u0483\u0000\u0000\u1c6e\u1c6f\u0003\u02a0\u0150\u0000\u1c6f\u1c77"+
		"\u0001\u0000\u0000\u0000\u1c70\u1c71\u0005\u012c\u0000\u0000\u1c71\u1c72"+
		"\u0005\u0482\u0000\u0000\u1c72\u1c73\u0003\u0256\u012b\u0000\u1c73\u1c74"+
		"\u0005\u0483\u0000\u0000\u1c74\u1c75\u0003\u02a0\u0150\u0000\u1c75\u1c77"+
		"\u0001\u0000\u0000\u0000\u1c76\u1c50\u0001\u0000\u0000\u0000\u1c76\u1c5e"+
		"\u0001\u0000\u0000\u0000\u1c76\u1c64\u0001\u0000\u0000\u0000\u1c76\u1c68"+
		"\u0001\u0000\u0000\u0000\u1c76\u1c70\u0001\u0000\u0000\u0000\u1c77\u029f"+
		"\u0001\u0000\u0000\u0000\u1c78\u1c7f\u0005\u0080\u0000\u0000\u1c79\u1c7b"+
		"\u0005\u0482\u0000\u0000\u1c7a\u1c7c\u0003\u02a2\u0151\u0000\u1c7b\u1c7a"+
		"\u0001\u0000\u0000\u0000\u1c7b\u1c7c\u0001\u0000\u0000\u0000\u1c7c\u1c7d"+
		"\u0001\u0000\u0000\u0000\u1c7d\u1c80\u0005\u0483\u0000\u0000\u1c7e\u1c80"+
		"\u0003\u02a4\u0152\u0000\u1c7f\u1c79\u0001\u0000\u0000\u0000\u1c7f\u1c7e"+
		"\u0001\u0000\u0000\u0000\u1c80\u02a1\u0001\u0000\u0000\u0000\u1c81\u1c83"+
		"\u0003\u02a4\u0152\u0000\u1c82\u1c81\u0001\u0000\u0000\u0000\u1c82\u1c83"+
		"\u0001\u0000\u0000\u0000\u1c83\u1c85\u0001\u0000\u0000\u0000\u1c84\u1c86"+
		"\u0003\u02b0\u0158\u0000\u1c85\u1c84\u0001\u0000\u0000\u0000\u1c85\u1c86"+
		"\u0001\u0000\u0000\u0000\u1c86\u1c88\u0001\u0000\u0000\u0000\u1c87\u1c89"+
		"\u0003\u00f0x\u0000\u1c88\u1c87\u0001\u0000\u0000\u0000\u1c88\u1c89\u0001"+
		"\u0000\u0000\u0000\u1c89\u1c8b\u0001\u0000\u0000\u0000\u1c8a\u1c8c\u0003"+
		"\u02a6\u0153\u0000\u1c8b\u1c8a\u0001\u0000\u0000\u0000\u1c8b\u1c8c\u0001"+
		"\u0000\u0000\u0000\u1c8c\u02a3\u0001\u0000\u0000\u0000\u1c8d\u1c8e\u0003"+
		"\u0250\u0128\u0000\u1c8e\u02a5\u0001\u0000\u0000\u0000\u1c8f\u1c90\u0003"+
		"\u02a8\u0154\u0000\u1c90\u1c91\u0003\u02aa\u0155\u0000\u1c91\u02a7\u0001"+
		"\u0000\u0000\u0000\u1c92\u1c93\u0007\u0089\u0000\u0000\u1c93\u02a9\u0001"+
		"\u0000\u0000\u0000\u1c94\u1c97\u0003\u02ae\u0157\u0000\u1c95\u1c97\u0003"+
		"\u02ac\u0156\u0000\u1c96\u1c94\u0001\u0000\u0000\u0000\u1c96\u1c95\u0001"+
		"\u0000\u0000\u0000\u1c97\u02ab\u0001\u0000\u0000\u0000\u1c98\u1c99\u0005"+
		"\u0010\u0000\u0000\u1c99\u1c9a\u0003\u02ae\u0157\u0000\u1c9a\u1c9b\u0005"+
		"\n\u0000\u0000\u1c9b\u1c9c\u0003\u02ae\u0157\u0000\u1c9c\u02ad\u0001\u0000"+
		"\u0000\u0000\u1c9d\u1c9e\u0005$\u0000\u0000\u1c9e\u1ca5\u0005\u025a\u0000"+
		"\u0000\u1c9f\u1ca0\u0005\u0295\u0000\u0000\u1ca0\u1ca5\u0007\u008a\u0000"+
		"\u0000\u1ca1\u1ca2\u0003\u02ba\u015d\u0000\u1ca2\u1ca3\u0007\u008a\u0000"+
		"\u0000\u1ca3\u1ca5\u0001\u0000\u0000\u0000\u1ca4\u1c9d\u0001\u0000\u0000"+
		"\u0000\u1ca4\u1c9f\u0001\u0000\u0000\u0000\u1ca4\u1ca1\u0001\u0000\u0000"+
		"\u0000\u1ca5\u02af\u0001\u0000\u0000\u0000\u1ca6\u1ca7\u0005\u0081\u0000"+
		"\u0000\u1ca7\u1ca8\u0005\u0014\u0000\u0000\u1ca8\u1cad\u0003\u02ba\u015d"+
		"\u0000\u1ca9\u1caa\u0005\u0484\u0000\u0000\u1caa\u1cac\u0003\u02ba\u015d"+
		"\u0000\u1cab\u1ca9\u0001\u0000\u0000\u0000\u1cac\u1caf\u0001\u0000\u0000"+
		"\u0000\u1cad\u1cab\u0001\u0000\u0000\u0000\u1cad\u1cae\u0001\u0000\u0000"+
		"\u0000\u1cae\u02b1\u0001\u0000\u0000\u0000\u1caf\u1cad\u0001\u0000\u0000"+
		"\u0000\u1cb0\u1cc8\u0003\u02d8\u016c\u0000\u1cb1\u1cc8\u0005\u02f2\u0000"+
		"\u0000\u1cb2\u1cc8\u0005\u013d\u0000\u0000\u1cb3\u1cc8\u0005\u0139\u0000"+
		"\u0000\u1cb4\u1cc8\u0005\u013a\u0000\u0000\u1cb5\u1cc8\u0005\u013b\u0000"+
		"\u0000\u1cb6\u1cc8\u0005\u013e\u0000\u0000\u1cb7\u1cc8\u0005\u013f\u0000"+
		"\u0000\u1cb8\u1cc8\u0005\u0140\u0000\u0000\u1cb9\u1cc8\u0005M\u0000\u0000"+
		"\u1cba\u1cc8\u0005U\u0000\u0000\u1cbb\u1cc8\u0005\u013c\u0000\u0000\u1cbc"+
		"\u1cc8\u0005\u0142\u0000\u0000\u1cbd\u1cc8\u0005\u01fd\u0000\u0000\u1cbe"+
		"\u1cc8\u0005\u0143\u0000\u0000\u1cbf\u1cc8\u0005\u008e\u0000\u0000\u1cc0"+
		"\u1cc8\u0005\u0145\u0000\u0000\u1cc1\u1cc8\u0005\u0146\u0000\u0000\u1cc2"+
		"\u1cc8\u0005\u0147\u0000\u0000\u1cc3\u1cc8\u0005\u0148\u0000\u0000\u1cc4"+
		"\u1cc8\u0005\u0149\u0000\u0000\u1cc5\u1cc8\u0005\u014a\u0000\u0000\u1cc6"+
		"\u1cc8\u0005\u014b\u0000\u0000\u1cc7\u1cb0\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cb1\u0001\u0000\u0000\u0000\u1cc7\u1cb2\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cb3\u0001\u0000\u0000\u0000\u1cc7\u1cb4\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cb5\u0001\u0000\u0000\u0000\u1cc7\u1cb6\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cb7\u0001\u0000\u0000\u0000\u1cc7\u1cb8\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cb9\u0001\u0000\u0000\u0000\u1cc7\u1cba\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cbb\u0001\u0000\u0000\u0000\u1cc7\u1cbc\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cbd\u0001\u0000\u0000\u0000\u1cc7\u1cbe\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cbf\u0001\u0000\u0000\u0000\u1cc7\u1cc0\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cc1\u0001\u0000\u0000\u0000\u1cc7\u1cc2\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cc3\u0001\u0000\u0000\u0000\u1cc7\u1cc4\u0001\u0000\u0000\u0000\u1cc7"+
		"\u1cc5\u0001\u0000\u0000\u0000\u1cc7\u1cc6\u0001\u0000\u0000\u0000\u1cc8"+
		"\u02b3\u0001\u0000\u0000\u0000\u1cc9\u1cca\u0007\u008b\u0000\u0000\u1cca"+
		"\u1ccb\u0005\u0482\u0000\u0000\u1ccb\u1ccc\u0003\u02b8\u015c\u0000\u1ccc"+
		"\u1ccd\u0005\u0483\u0000\u0000\u1ccd\u02b5\u0001\u0000\u0000\u0000\u1cce"+
		"\u1cd3\u0003\u0262\u0131\u0000\u1ccf\u1cd3\u0003\u0232\u0119\u0000\u1cd0"+
		"\u1cd3\u0003\u0292\u0149\u0000\u1cd1\u1cd3\u0003\u02ba\u015d\u0000\u1cd2"+
		"\u1cce\u0001\u0000\u0000\u0000\u1cd2\u1ccf\u0001\u0000\u0000\u0000\u1cd2"+
		"\u1cd0\u0001\u0000\u0000\u0000\u1cd2\u1cd1\u0001\u0000\u0000\u0000\u1cd3"+
		"\u1cdd\u0001\u0000\u0000\u0000\u1cd4\u1cd9\u0005\u0484\u0000\u0000\u1cd5"+
		"\u1cda\u0003\u0262\u0131\u0000\u1cd6\u1cda\u0003\u0232\u0119\u0000\u1cd7"+
		"\u1cda\u0003\u0292\u0149\u0000\u1cd8\u1cda\u0003\u02ba\u015d\u0000\u1cd9"+
		"\u1cd5\u0001\u0000\u0000\u0000\u1cd9\u1cd6\u0001\u0000\u0000\u0000\u1cd9"+
		"\u1cd7\u0001\u0000\u0000\u0000\u1cd9\u1cd8\u0001\u0000\u0000\u0000\u1cda"+
		"\u1cdc\u0001\u0000\u0000\u0000\u1cdb\u1cd4\u0001\u0000\u0000\u0000\u1cdc"+
		"\u1cdf\u0001\u0000\u0000\u0000\u1cdd\u1cdb\u0001\u0000\u0000\u0000\u1cdd"+
		"\u1cde\u0001\u0000\u0000\u0000\u1cde\u02b7\u0001\u0000\u0000\u0000\u1cdf"+
		"\u1cdd\u0001\u0000\u0000\u0000\u1ce0\u1ce5\u0003\u0262\u0131\u0000\u1ce1"+
		"\u1ce5\u0003\u0232\u0119\u0000\u1ce2\u1ce5\u0003\u0292\u0149\u0000\u1ce3"+
		"\u1ce5\u0003\u02ba\u015d\u0000\u1ce4\u1ce0\u0001\u0000\u0000\u0000\u1ce4"+
		"\u1ce1\u0001\u0000\u0000\u0000\u1ce4\u1ce2\u0001\u0000\u0000\u0000\u1ce4"+
		"\u1ce3\u0001\u0000\u0000\u0000\u1ce5\u02b9\u0001\u0000\u0000\u0000\u1ce6"+
		"\u1ce7\u0006\u015d\uffff\uffff\u0000\u1ce7\u1ce8\u0007\u008c\u0000\u0000"+
		"\u1ce8\u1cf2\u0003\u02ba\u015d\u0004\u1ce9\u1cea\u0003\u02bc\u015e\u0000"+
		"\u1cea\u1cec\u0005X\u0000\u0000\u1ceb\u1ced\u0005r\u0000\u0000\u1cec\u1ceb"+
		"\u0001\u0000\u0000\u0000\u1cec\u1ced\u0001\u0000\u0000\u0000\u1ced\u1cee"+
		"\u0001\u0000\u0000\u0000\u1cee\u1cef\u0007\u008d\u0000\u0000\u1cef\u1cf2"+
		"\u0001\u0000\u0000\u0000\u1cf0\u1cf2\u0003\u02bc\u015e\u0000\u1cf1\u1ce6"+
		"\u0001\u0000\u0000\u0000\u1cf1\u1ce9\u0001\u0000\u0000\u0000\u1cf1\u1cf0"+
		"\u0001\u0000\u0000\u0000\u1cf2\u1cf9\u0001\u0000\u0000\u0000\u1cf3\u1cf4"+
		"\n\u0003\u0000\u0000\u1cf4\u1cf5\u0003\u02c4\u0162\u0000\u1cf5\u1cf6\u0003"+
		"\u02ba\u015d\u0004\u1cf6\u1cf8\u0001\u0000\u0000\u0000\u1cf7\u1cf3\u0001"+
		"\u0000\u0000\u0000\u1cf8\u1cfb\u0001\u0000\u0000\u0000\u1cf9\u1cf7\u0001"+
		"\u0000\u0000\u0000\u1cf9\u1cfa\u0001\u0000\u0000\u0000\u1cfa\u02bb\u0001"+
		"\u0000\u0000\u0000\u1cfb\u1cf9\u0001\u0000\u0000\u0000\u1cfc\u1cfd\u0006"+
		"\u015e\uffff\uffff\u0000\u1cfd\u1cfe\u0003\u02be\u015f\u0000\u1cfe\u1d3f"+
		"\u0001\u0000\u0000\u0000\u1cff\u1d00\n\b\u0000\u0000\u1d00\u1d01\u0003"+
		"\u02c2\u0161\u0000\u1d01\u1d02\u0003\u02bc\u015e\t\u1d02\u1d3e\u0001\u0000"+
		"\u0000\u0000\u1d03\u1d05\n\u0006\u0000\u0000\u1d04\u1d06\u0005r\u0000"+
		"\u0000\u1d05\u1d04\u0001\u0000\u0000\u0000\u1d05\u1d06\u0001\u0000\u0000"+
		"\u0000\u1d06\u1d07\u0001\u0000\u0000\u0000\u1d07\u1d08\u0005\u0010\u0000"+
		"\u0000\u1d08\u1d09\u0003\u02bc\u015e\u0000\u1d09\u1d0a\u0005\n\u0000\u0000"+
		"\u1d0a\u1d0b\u0003\u02bc\u015e\u0007\u1d0b\u1d3e\u0001\u0000\u0000\u0000"+
		"\u1d0c\u1d0d\n\u0005\u0000\u0000\u1d0d\u1d0e\u0005\u026f\u0000\u0000\u1d0e"+
		"\u1d0f\u0005b\u0000\u0000\u1d0f\u1d3e\u0003\u02bc\u015e\u0006\u1d10\u1d12"+
		"\n\u0003\u0000\u0000\u1d11\u1d13\u0005r\u0000\u0000\u1d12\u1d11\u0001"+
		"\u0000\u0000\u0000\u1d12\u1d13\u0001\u0000\u0000\u0000\u1d13\u1d14\u0001"+
		"\u0000\u0000\u0000\u1d14\u1d15\u0007\u008e\u0000\u0000\u1d15\u1d3e\u0003"+
		"\u02bc\u015e\u0004\u1d16\u1d18\n\n\u0000\u0000\u1d17\u1d19\u0005r\u0000"+
		"\u0000\u1d18\u1d17\u0001\u0000\u0000\u0000\u1d18\u1d19\u0001\u0000\u0000"+
		"\u0000\u1d19\u1d1a\u0001\u0000\u0000\u0000\u1d1a\u1d1b\u0005P\u0000\u0000"+
		"\u1d1b\u1d1e\u0005\u0482\u0000\u0000\u1d1c\u1d1f\u0003\u00d2i\u0000\u1d1d"+
		"\u1d1f\u0003\u0278\u013c\u0000\u1d1e\u1d1c\u0001\u0000\u0000\u0000\u1d1e"+
		"\u1d1d\u0001\u0000\u0000\u0000\u1d1f\u1d20\u0001\u0000\u0000\u0000\u1d20"+
		"\u1d21\u0005\u0483\u0000\u0000\u1d21\u1d3e\u0001\u0000\u0000\u0000\u1d22"+
		"\u1d23\n\t\u0000\u0000\u1d23\u1d24\u0005X\u0000\u0000\u1d24\u1d3e\u0003"+
		"\u0260\u0130\u0000\u1d25\u1d26\n\u0007\u0000\u0000\u1d26\u1d27\u0003\u02c2"+
		"\u0161\u0000\u1d27\u1d28\u0007\u008f\u0000\u0000\u1d28\u1d29\u0005\u0482"+
		"\u0000\u0000\u1d29\u1d2a\u0003\u00d2i\u0000\u1d2a\u1d2b\u0005\u0483\u0000"+
		"\u0000\u1d2b\u1d3e\u0001\u0000\u0000\u0000\u1d2c\u1d2e\n\u0004\u0000\u0000"+
		"\u1d2d\u1d2f\u0005r\u0000\u0000\u1d2e\u1d2d\u0001\u0000\u0000\u0000\u1d2e"+
		"\u1d2f\u0001\u0000\u0000\u0000\u1d2f\u1d30\u0001\u0000\u0000\u0000\u1d30"+
		"\u1d31\u0005b\u0000\u0000\u1d31\u1d34\u0003\u02bc\u015e\u0000\u1d32\u1d33"+
		"\u0005\u019d\u0000\u0000\u1d33\u1d35\u0005\u0491\u0000\u0000\u1d34\u1d32"+
		"\u0001\u0000\u0000\u0000\u1d34\u1d35\u0001\u0000\u0000\u0000\u1d35\u1d3e"+
		"\u0001\u0000\u0000\u0000\u1d36\u1d37\n\u0002\u0000\u0000\u1d37\u1d38\u0005"+
		"\u01fa\u0000\u0000\u1d38\u1d39\u0005\u0216\u0000\u0000\u1d39\u1d3a\u0005"+
		"\u0482\u0000\u0000\u1d3a\u1d3b\u0003\u02bc\u015e\u0000\u1d3b\u1d3c\u0005"+
		"\u0483\u0000\u0000\u1d3c\u1d3e\u0001\u0000\u0000\u0000\u1d3d\u1cff\u0001"+
		"\u0000\u0000\u0000\u1d3d\u1d03\u0001\u0000\u0000\u0000\u1d3d\u1d0c\u0001"+
		"\u0000\u0000\u0000\u1d3d\u1d10\u0001\u0000\u0000\u0000\u1d3d\u1d16\u0001"+
		"\u0000\u0000\u0000\u1d3d\u1d22\u0001\u0000\u0000\u0000\u1d3d\u1d25\u0001"+
		"\u0000\u0000\u0000\u1d3d\u1d2c\u0001\u0000\u0000\u0000\u1d3d\u1d36\u0001"+
		"\u0000\u0000\u0000\u1d3e\u1d41\u0001\u0000\u0000\u0000\u1d3f\u1d3d\u0001"+
		"\u0000\u0000\u0000\u1d3f\u1d40\u0001\u0000\u0000\u0000\u1d40\u02bd\u0001"+
		"\u0000\u0000\u0000\u1d41\u1d3f\u0001\u0000\u0000\u0000\u1d42\u1d43\u0006"+
		"\u015f\uffff\uffff\u0000\u1d43\u1d73\u0003\u0262\u0131\u0000\u1d44\u1d73"+
		"\u0003\u0232\u0119\u0000\u1d45\u1d73\u0003\u0292\u0149\u0000\u1d46\u1d73"+
		"\u0003\u023c\u011e\u0000\u1d47\u1d48\u0003\u02c0\u0160\u0000\u1d48\u1d49"+
		"\u0003\u02be\u015f\u000b\u1d49\u1d73\u0001\u0000\u0000\u0000\u1d4a\u1d4b"+
		"\u0005\u00e2\u0000\u0000\u1d4b\u1d73\u0003\u02be\u015f\n\u1d4c\u1d4d\u0005"+
		"\u049c\u0000\u0000\u1d4d\u1d4e\u0005\u0469\u0000\u0000\u1d4e\u1d73\u0003"+
		"\u02be\u015f\t\u1d4f\u1d50\u0005\u0482\u0000\u0000\u1d50\u1d55\u0003\u02ba"+
		"\u015d\u0000\u1d51\u1d52\u0005\u0484\u0000\u0000\u1d52\u1d54\u0003\u02ba"+
		"\u015d\u0000\u1d53\u1d51\u0001\u0000\u0000\u0000\u1d54\u1d57\u0001\u0000"+
		"\u0000\u0000\u1d55\u1d53\u0001\u0000\u0000\u0000\u1d55\u1d56\u0001\u0000"+
		"\u0000\u0000\u1d56\u1d58\u0001\u0000\u0000\u0000\u1d57\u1d55\u0001\u0000"+
		"\u0000\u0000\u1d58\u1d59\u0005\u0483\u0000\u0000\u1d59\u1d73\u0001\u0000"+
		"\u0000\u0000\u1d5a\u1d5b\u0005\u025a\u0000\u0000\u1d5b\u1d5c\u0005\u0482"+
		"\u0000\u0000\u1d5c\u1d5f\u0003\u02ba\u015d\u0000\u1d5d\u1d5e\u0005\u0484"+
		"\u0000\u0000\u1d5e\u1d60\u0003\u02ba\u015d\u0000\u1d5f\u1d5d\u0001\u0000"+
		"\u0000\u0000\u1d60\u1d61\u0001\u0000\u0000\u0000\u1d61\u1d5f\u0001\u0000"+
		"\u0000\u0000\u1d61\u1d62\u0001\u0000\u0000\u0000\u1d62\u1d63\u0001\u0000"+
		"\u0000\u0000\u1d63\u1d64\u0005\u0483\u0000\u0000\u1d64\u1d73\u0001\u0000"+
		"\u0000\u0000\u1d65\u1d66\u0005<\u0000\u0000\u1d66\u1d67\u0005\u0482\u0000"+
		"\u0000\u1d67\u1d68\u0003\u00d2i\u0000\u1d68\u1d69\u0005\u0483\u0000\u0000"+
		"\u1d69\u1d73\u0001\u0000\u0000\u0000\u1d6a\u1d6b\u0005\u0482\u0000\u0000"+
		"\u1d6b\u1d6c\u0003\u00d2i\u0000\u1d6c\u1d6d\u0005\u0483\u0000\u0000\u1d6d"+
		"\u1d73\u0001\u0000\u0000\u0000\u1d6e\u1d6f\u0005V\u0000\u0000\u1d6f\u1d70"+
		"\u0003\u02ba\u015d\u0000\u1d70\u1d71\u0003N\'\u0000\u1d71\u1d73\u0001"+
		"\u0000\u0000\u0000\u1d72\u1d42\u0001\u0000\u0000\u0000\u1d72\u1d44\u0001"+
		"\u0000\u0000\u0000\u1d72\u1d45\u0001\u0000\u0000\u0000\u1d72\u1d46\u0001"+
		"\u0000\u0000\u0000\u1d72\u1d47\u0001\u0000\u0000\u0000\u1d72\u1d4a\u0001"+
		"\u0000\u0000\u0000\u1d72\u1d4c\u0001\u0000\u0000\u0000\u1d72\u1d4f\u0001"+
		"\u0000\u0000\u0000\u1d72\u1d5a\u0001\u0000\u0000\u0000\u1d72\u1d65\u0001"+
		"\u0000\u0000\u0000\u1d72\u1d6a\u0001\u0000\u0000\u0000\u1d72\u1d6e\u0001"+
		"\u0000\u0000\u0000\u1d73\u1d85\u0001\u0000\u0000\u0000\u1d74\u1d75\n\u0003"+
		"\u0000\u0000\u1d75\u1d76\u0003\u02c6\u0163\u0000\u1d76\u1d77\u0003\u02be"+
		"\u015f\u0004\u1d77\u1d84\u0001\u0000\u0000\u0000\u1d78\u1d79\n\u0002\u0000"+
		"\u0000\u1d79\u1d7a\u0003\u02c8\u0164\u0000\u1d7a\u1d7b\u0003\u02be\u015f"+
		"\u0003\u1d7b\u1d84\u0001\u0000\u0000\u0000\u1d7c\u1d7d\n\u0001\u0000\u0000"+
		"\u1d7d\u1d7e\u0003\u02ca\u0165\u0000\u1d7e\u1d7f\u0003\u02be\u015f\u0002"+
		"\u1d7f\u1d84\u0001\u0000\u0000\u0000\u1d80\u1d81\n\r\u0000\u0000\u1d81"+
		"\u1d82\u0005\u001c\u0000\u0000\u1d82\u1d84\u0003\u0240\u0120\u0000\u1d83"+
		"\u1d74\u0001\u0000\u0000\u0000\u1d83\u1d78\u0001\u0000\u0000\u0000\u1d83"+
		"\u1d7c\u0001\u0000\u0000\u0000\u1d83\u1d80\u0001\u0000\u0000\u0000\u1d84"+
		"\u1d87\u0001\u0000\u0000\u0000\u1d85\u1d83\u0001\u0000\u0000\u0000\u1d85"+
		"\u1d86\u0001\u0000\u0000\u0000\u1d86\u02bf\u0001\u0000\u0000\u0000\u1d87"+
		"\u1d85\u0001\u0000\u0000\u0000\u1d88\u1d89\u0007\u0090\u0000\u0000\u1d89"+
		"\u02c1\u0001\u0000\u0000\u0000\u1d8a\u1d99\u0005\u0479\u0000\u0000\u1d8b"+
		"\u1d99\u0005\u047a\u0000\u0000\u1d8c\u1d99\u0005\u047b\u0000\u0000\u1d8d"+
		"\u1d8e\u0005\u047b\u0000\u0000\u1d8e\u1d99\u0005\u0479\u0000\u0000\u1d8f"+
		"\u1d90\u0005\u047a\u0000\u0000\u1d90\u1d99\u0005\u0479\u0000\u0000\u1d91"+
		"\u1d92\u0005\u047b\u0000\u0000\u1d92\u1d99\u0005\u047a\u0000\u0000\u1d93"+
		"\u1d94\u0005\u047c\u0000\u0000\u1d94\u1d99\u0005\u0479\u0000\u0000\u1d95"+
		"\u1d96\u0005\u047b\u0000\u0000\u1d96\u1d97\u0005\u0479\u0000\u0000\u1d97"+
		"\u1d99\u0005\u047a\u0000\u0000\u1d98\u1d8a\u0001\u0000\u0000\u0000\u1d98"+
		"\u1d8b\u0001\u0000\u0000\u0000\u1d98\u1d8c\u0001\u0000\u0000\u0000\u1d98"+
		"\u1d8d\u0001\u0000\u0000\u0000\u1d98\u1d8f\u0001\u0000\u0000\u0000\u1d98"+
		"\u1d91\u0001\u0000\u0000\u0000\u1d98\u1d93\u0001\u0000\u0000\u0000\u1d98"+
		"\u1d95\u0001\u0000\u0000\u0000\u1d99\u02c3\u0001\u0000\u0000\u0000\u1d9a"+
		"\u1da2\u0005\n\u0000\u0000\u1d9b\u1d9c\u0005\u047f\u0000\u0000\u1d9c\u1da2"+
		"\u0005\u047f\u0000\u0000\u1d9d\u1da2\u0005\u00c2\u0000\u0000\u1d9e\u1da2"+
		"\u0005{\u0000\u0000\u1d9f\u1da0\u0005\u047e\u0000\u0000\u1da0\u1da2\u0005"+
		"\u047e\u0000\u0000\u1da1\u1d9a\u0001\u0000\u0000\u0000\u1da1\u1d9b\u0001"+
		"\u0000\u0000\u0000\u1da1\u1d9d\u0001\u0000\u0000\u0000\u1da1\u1d9e\u0001"+
		"\u0000\u0000\u0000\u1da1\u1d9f\u0001\u0000\u0000\u0000\u1da2\u02c5\u0001"+
		"\u0000\u0000\u0000\u1da3\u1da4\u0005\u047b\u0000\u0000\u1da4\u1dab\u0005"+
		"\u047b\u0000\u0000\u1da5\u1da6\u0005\u047a\u0000\u0000\u1da6\u1dab\u0005"+
		"\u047a\u0000\u0000\u1da7\u1dab\u0005\u047f\u0000\u0000\u1da8\u1dab\u0005"+
		"\u0480\u0000\u0000\u1da9\u1dab\u0005\u047e\u0000\u0000\u1daa\u1da3\u0001"+
		"\u0000\u0000\u0000\u1daa\u1da5\u0001\u0000\u0000\u0000\u1daa\u1da7\u0001"+
		"\u0000\u0000\u0000\u1daa\u1da8\u0001\u0000\u0000\u0000\u1daa\u1da9\u0001"+
		"\u0000\u0000\u0000\u1dab\u02c7\u0001\u0000\u0000\u0000\u1dac\u1dad\u0007"+
		"\u0091\u0000\u0000\u1dad\u02c9\u0001\u0000\u0000\u0000\u1dae\u1daf\u0005"+
		"\u0476\u0000\u0000\u1daf\u1db4\u0005\u047a\u0000\u0000\u1db0\u1db1\u0005"+
		"\u0476\u0000\u0000\u1db1\u1db2\u0005\u047a\u0000\u0000\u1db2\u1db4\u0005"+
		"\u047a\u0000\u0000\u1db3\u1dae\u0001\u0000\u0000\u0000\u1db3\u1db0\u0001"+
		"\u0000\u0000\u0000\u1db4\u02cb\u0001\u0000\u0000\u0000\u1db5\u1db6\u0007"+
		"\u0092\u0000\u0000\u1db6\u02cd\u0001\u0000\u0000\u0000\u1db7\u1db8\u0007"+
		"\u0093\u0000\u0000\u1db8\u02cf\u0001\u0000\u0000\u0000\u1db9\u1dba\u0007"+
		"\u0094\u0000\u0000\u1dba\u02d1\u0001\u0000\u0000\u0000\u1dbb\u1dbc\u0007"+
		"\u0095\u0000\u0000\u1dbc\u02d3\u0001\u0000\u0000\u0000\u1dbd\u1dbe\u0007"+
		"\u0096\u0000\u0000\u1dbe\u02d5\u0001\u0000\u0000\u0000\u1dbf\u1dc0\u0007"+
		"\u0097\u0000\u0000\u1dc0\u02d7\u0001\u0000\u0000\u0000\u1dc1\u1dc2\u0007"+
		"\u0098\u0000\u0000\u1dc2\u02d9\u0001\u0000\u0000\u0000\u0463\u02db\u02df"+
		"\u02e6\u02e9\u02ec\u02ee\u02f4\u02f7\u02fa\u02fd\u0306\u0313\u0343\u0350"+
		"\u035b\u036c\u0371\u0380\u039c\u03a5\u03aa\u03b0\u03b5\u03b9\u03c2\u03c5"+
		"\u03c8\u03cc\u03d3\u03d6\u03d9\u03dd\u03e1\u03e7\u03ec\u03f1\u03f6\u03f9"+
		"\u03fb\u0407\u040a\u040e\u0411\u0415\u0418\u041c\u041f\u0422\u0426\u0429"+
		"\u042d\u0433\u0436\u043c\u0442\u0449\u0450\u0453\u0456\u045a\u045f\u0465"+
		"\u046e\u0473\u0478\u047f\u0490\u0497\u049a\u049e\u04a8\u04ac\u04af\u04b3"+
		"\u04b7\u04bb\u04c0\u04c3\u04c6\u04c9\u04cc\u04d2\u04d5\u04d9\u04df\u04e4"+
		"\u04e7\u04ea\u04ec\u04f7\u04fb\u04fe\u050c\u050f\u0513\u0516\u051a\u051d"+
		"\u0521\u0524\u0528\u052b\u052e\u0532\u0535\u0539\u053f\u0542\u054f\u0555"+
		"\u0560\u0565\u056d\u0575\u057a\u057d\u0582\u058a\u058f\u0595\u059a\u059e"+
		"\u05a0\u05a4\u05a7\u05ab\u05b0\u05b2\u05b7\u05bc\u05c4\u05cc\u05d1\u05d9"+
		"\u05dc\u05df\u05e3\u05e7\u05ea\u05ee\u05f2\u05f6\u05fc\u05ff\u0606\u060b"+
		"\u0612\u0619\u061f\u0627\u062a\u0631\u0634\u0636\u063c\u0642\u0653\u065a"+
		"\u0661\u066d\u0672\u067b\u067d\u0680\u068d\u069a\u069f\u06af\u06b7\u06c1"+
		"\u06c7\u06d3\u06d6\u06db\u06e8\u06ef\u06f6\u06f8\u06ff\u0703\u0705\u070a"+
		"\u070d\u0713\u0718\u071a\u071e\u0721\u0724\u072a\u072f\u0731\u0736\u073d"+
		"\u073f\u0746\u074b\u074f\u0752\u075a\u0762\u0764\u076c\u0770\u0773\u0779"+
		"\u077e\u0781\u0787\u078a\u078e\u0791\u0795\u079a\u079f\u07a4\u07a8\u07ac"+
		"\u07b0\u07b4\u07b8\u07bc\u07c1\u07c6\u07cb\u07d1\u07d6\u07db\u07e0\u07e6"+
		"\u07eb\u07f0\u07f6\u07fb\u0800\u0805\u080a\u080f\u0814\u0819\u0820\u0825"+
		"\u082a\u082f\u0833\u0838\u0840\u0845\u084b\u0857\u085e\u0860\u0868\u086d"+
		"\u0870\u0878\u087e\u088e\u089a\u089c\u089f\u08a7\u08ad\u08b3\u08c0\u08c7"+
		"\u08d0\u08d5\u08e0\u08e9\u08ee\u08fa\u0901\u090a\u090f\u091b\u0922\u092b"+
		"\u0930\u0937\u0940\u0945\u0947\u094c\u0954\u095d\u0961\u0964\u0968\u096d"+
		"\u0973\u0979\u097e\u0983\u0988\u098d\u0990\u0995\u099a\u09a4\u09a8\u09af"+
		"\u09b4\u09b7\u09bc\u09bf\u09c3\u09c7\u09cf\u09e2\u09e5\u09e8\u09ec\u09f6"+
		"\u0a03\u0a0a\u0a0d\u0a11\u0a15\u0a1c\u0a1f\u0a22\u0a2d\u0a30\u0a34\u0a3c"+
		"\u0a3f\u0a44\u0a4c\u0a52\u0a56\u0a5b\u0a61\u0a65\u0a6a\u0a6f\u0a72\u0a79"+
		"\u0a7d\u0a80\u0a8b\u0a93\u0a96\u0a99\u0a9f\u0aa5\u0aa7\u0aac\u0aaf\u0ab5"+
		"\u0abb\u0abd\u0ac1\u0ac4\u0ac7\u0aca\u0ad0\u0ad6\u0ad9\u0adf\u0ae5\u0ae7"+
		"\u0aec\u0aef\u0af7\u0af9\u0b02\u0b07\u0b0f\u0b13\u0b16\u0b1e\u0b28\u0b2d"+
		"\u0b30\u0b37\u0b3b\u0b3e\u0b42\u0b47\u0b50\u0b62\u0b66\u0b6e\u0b72\u0b7e"+
		"\u0b81\u0b8a\u0b95\u0b98\u0ba0\u0ba6\u0bab\u0bb3\u0bbb\u0bc2\u0bc9\u0bd0"+
		"\u0bdf\u0bec\u0bf2\u0bf8\u0bfe\u0c04\u0c0a\u0c10\u0c15\u0c1c\u0c23\u0c26"+
		"\u0c2d\u0c32\u0c35\u0c37\u0c3b\u0c48\u0c4f\u0c56\u0c5c\u0c60\u0c64\u0c67"+
		"\u0c6e\u0c71\u0c76\u0c7d\u0c84\u0c88\u0c8d\u0c94\u0ca1\u0ca4\u0ca9\u0cae"+
		"\u0cb2\u0cb8\u0cbc\u0cc0\u0cc3\u0cca\u0cd0\u0cd7\u0cdc\u0ce3\u0ce7\u0cee"+
		"\u0cf1\u0cf5\u0cfe\u0d02\u0d05\u0d08\u0d0e\u0d11\u0d17\u0d20\u0d23\u0d2e"+
		"\u0d31\u0d36\u0d39\u0d3e\u0d48\u0d4d\u0d53\u0d55\u0d5b\u0d5d\u0d63\u0d6b"+
		"\u0d70\u0d78\u0d7b\u0d80\u0d83\u0d88\u0d90\u0d98\u0d9e\u0da6\u0dab\u0db3"+
		"\u0db6\u0dba\u0dbd\u0dc5\u0dcb\u0dd4\u0dd7\u0ddb\u0ddf\u0de5\u0de9\u0ded"+
		"\u0def\u0df2\u0df5\u0df8\u0dfe\u0e02\u0e05\u0e08\u0e0b\u0e0e\u0e15\u0e17"+
		"\u0e1b\u0e20\u0e26\u0e2b\u0e32\u0e38\u0e3d\u0e40\u0e46\u0e4a\u0e52\u0e55"+
		"\u0e59\u0e5c\u0e5f\u0e68\u0e6c\u0e6f\u0e73\u0e77\u0e7a\u0e7d\u0e82\u0e88"+
		"\u0e8c\u0e96\u0e9c\u0ea0\u0ea6\u0eaa\u0eb0\u0eb3\u0ebf\u0ec3\u0ec7\u0ecf"+
		"\u0ed3\u0edb\u0ede\u0ee2\u0ee5\u0eed\u0ef2\u0ef5\u0ef8\u0efc\u0eff\u0f08"+
		"\u0f0d\u0f16\u0f1b\u0f22\u0f29\u0f31\u0f37\u0f3f\u0f42\u0f45\u0f4c\u0f4f"+
		"\u0f56\u0f59\u0f61\u0f67\u0f72\u0f75\u0f79\u0f83\u0f89\u0f8d\u0f91\u0f9b"+
		"\u0fa0\u0fa2\u0fa6\u0fb0\u0fba\u0fc0\u0fc5\u0fc8\u0fcb\u0fce\u0fd1\u0fd4"+
		"\u0fd7\u0fdd\u0fe2\u0fe5\u0fe8\u0feb\u0fee\u0ff1\u0ff4\u0ff6\u0ffc\u1001"+
		"\u1004\u1007\u100a\u100d\u1010\u1014\u101a\u101e\u1026\u102a\u102d\u102f"+
		"\u103c\u103f\u1046\u1050\u1053\u1058\u105a\u105e\u1066\u106c\u1075\u1082"+
		"\u1086\u108c\u1095\u1098\u109c\u109f\u10a3\u10a7\u10aa\u10ac\u10b4\u10c0"+
		"\u10c6\u10c8\u10ce\u10d0\u10d2\u10d8\u10e0\u10e8\u10ec\u10f0\u10f9\u10fe"+
		"\u1112\u1117\u111d\u1124\u1129\u1132\u1135\u1139\u113d\u1141\u1144\u1147"+
		"\u114a\u114e\u1152\u1155\u1158\u115b\u1162\u1166\u1175\u1179\u1185\u118d"+
		"\u1197\u119b\u119e\u11a4\u11a7\u11aa\u11b3\u11bc\u11c6\u11ca\u11d4\u11de"+
		"\u11e6\u11e9\u11f2\u11f5\u11f9\u11fe\u1202\u120b\u120e\u122d\u1230\u1233"+
		"\u126b\u1270\u128c\u129a\u12a1\u12a5\u12ab\u12b3\u12b5\u12c0\u12ca\u12d1"+
		"\u12d7\u12df\u12e4\u12ec\u12f4\u12fc\u1304\u130a\u130d\u1311\u1316\u131b"+
		"\u1321\u1323\u132e\u1333\u133a\u133c\u134a\u1350\u1355\u135a\u1360\u1367"+
		"\u136f\u1377\u137c\u1382\u1385\u138d\u1394\u139d\u13a0\u13b1\u13b9\u13c1"+
		"\u13c5\u13cc\u13d2\u13da\u13e3\u13e9\u13f0\u13f7\u13fc\u13ff\u1401\u1407"+
		"\u1409\u140d\u140f\u1416\u1418\u1421\u1427\u142e\u1435\u143a\u143d\u143f"+
		"\u1445\u1447\u144b\u144d\u1454\u1456\u145b\u1462\u146b\u1470\u1479\u1480"+
		"\u1485\u1488\u148a\u1490\u1492\u1495\u149d\u14a2\u14a7\u14ab\u14b1\u14b6"+
		"\u14ba\u14c0\u14c2\u14cd\u14d0\u14d7\u14da\u14e6\u14ec\u14f5\u14fe\u1503"+
		"\u150c\u1512\u151d\u1526\u152c\u1531\u1535\u1538\u1544\u154b\u1550\u1562"+
		"\u156c\u1570\u1575\u157b\u1585\u158f\u1599\u159f\u15a8\u15ae\u15b5\u15b7"+
		"\u15c1\u15c5\u15c9\u15d3\u15d8\u15ea\u1622\u163b\u164d\u1655\u1661\u1668"+
		"\u166a\u1674\u1677\u167f\u1686\u168a\u168f\u1693\u1698\u169b\u169e\u16a7"+
		"\u16ab\u16ae\u16b2\u16c9\u16d0\u16d4\u16db\u16e2\u16e5\u16f5\u16f8\u1702"+
		"\u1706\u1709\u170e\u1713\u1717\u171a\u171f\u1724\u1728\u172f\u1732\u1738"+
		"\u1743\u1757\u1763\u1766\u1770\u1778\u177c\u1783\u1786\u178f\u1792\u1797"+
		"\u179a\u179f\u17a5\u17ac\u17b3\u17b7\u17b9\u17bd\u17c7\u17ca\u17cd\u17d9"+
		"\u17dc\u17e2\u17e5\u17ee\u17f0\u17f4\u1805\u180b\u180f\u181d\u1829\u1830"+
		"\u1833\u183a\u1841\u1846\u184a\u1857\u1862\u1868\u186d\u187a\u187c\u1881"+
		"\u1885\u1888\u188a\u1891\u1898\u189b\u189e\u18a4\u18a8\u18ae\u18b4\u18c5"+
		"\u18ca\u18d2\u18d5\u18da\u18df\u18e7\u18ea\u18f2\u18f6\u1903\u1909\u1915"+
		"\u1918\u1921\u1926\u192c\u1932\u1937\u1939\u193e\u1940\u1944\u194a\u194d"+
		"\u1950\u1956\u195f\u1967\u196b\u1970\u1986\u198d\u198f\u1996\u1998\u199c"+
		"\u19a1\u19ac\u19b1\u19b7\u19ba\u19be\u19c3\u19c6\u19ca\u19ce\u19d0\u19d5"+
		"\u19da\u19e7\u19ea\u19ee\u19f1\u19f4\u19f9\u19fe\u1a03\u1a06\u1a0b\u1a0e"+
		"\u1a14\u1a17\u1a1b\u1a20\u1a25\u1a2a\u1a2f\u1a32\u1a37\u1a3c\u1a41\u1a47"+
		"\u1a4c\u1a51\u1a56\u1a59\u1a5e\u1a62\u1a66\u1a6e\u1a77\u1a7b\u1a80\u1a85"+
		"\u1a89\u1a8b\u1a8e\u1a9e\u1aa7\u1aaf\u1ab8\u1ac2\u1aca\u1ad2\u1ada\u1ae2"+
		"\u1aee\u1af5\u1b08\u1b0d\u1b10\u1b15\u1b18\u1b1c\u1b2b\u1b30\u1b38\u1b3f"+
		"\u1b44\u1b49\u1b6a\u1b6e\u1b76\u1b7a\u1b83\u1b8b\u1b90\u1b98\u1b9d\u1ba2"+
		"\u1ba4\u1bad\u1bb2\u1bba\u1bbf\u1bc7\u1bcf\u1bd2\u1bdc\u1bee\u1bf1\u1bf4"+
		"\u1bf8\u1c05\u1c0d\u1c11\u1c16\u1c1b\u1c21\u1c26\u1c2a\u1c2f\u1c34\u1c39"+
		"\u1c43\u1c46\u1c4a\u1c4e\u1c55\u1c59\u1c76\u1c7b\u1c7f\u1c82\u1c85\u1c88"+
		"\u1c8b\u1c96\u1ca4\u1cad\u1cc7\u1cd2\u1cd9\u1cdd\u1ce4\u1cec\u1cf1\u1cf9"+
		"\u1d05\u1d12\u1d18\u1d1e\u1d2e\u1d34\u1d3d\u1d3f\u1d55\u1d61\u1d72\u1d83"+
		"\u1d85\u1d98\u1da1\u1daa\u1db3";
	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 - 2024 Weber Informatics LLC | Privacy Policy