// Generated from /Users/liuyi/Desktop/Projects/dtstack/dt-sql-parser/src/grammar/spark/SparkSqlParser.g4 by ANTLR 4.9.0-SNAPSHOT import { ATN } from "antlr4ts/atn/ATN"; import { ATNDeserializer } from "antlr4ts/atn/ATNDeserializer"; import { FailedPredicateException } from "antlr4ts/FailedPredicateException"; import { NotNull } from "antlr4ts/Decorators"; import { NoViableAltException } from "antlr4ts/NoViableAltException"; import { Override } from "antlr4ts/Decorators"; import { Parser } from "antlr4ts/Parser"; import { ParserRuleContext } from "antlr4ts/ParserRuleContext"; import { ParserATNSimulator } from "antlr4ts/atn/ParserATNSimulator"; import { ParseTreeListener } from "antlr4ts/tree/ParseTreeListener"; import { ParseTreeVisitor } from "antlr4ts/tree/ParseTreeVisitor"; import { RecognitionException } from "antlr4ts/RecognitionException"; import { RuleContext } from "antlr4ts/RuleContext"; //import { RuleVersion } from "antlr4ts/RuleVersion"; import { TerminalNode } from "antlr4ts/tree/TerminalNode"; import { Token } from "antlr4ts/Token"; import { TokenStream } from "antlr4ts/TokenStream"; import { Vocabulary } from "antlr4ts/Vocabulary"; import { VocabularyImpl } from "antlr4ts/VocabularyImpl"; import * as Utils from "antlr4ts/misc/Utils"; import { SparkSqlParserListener } from "./SparkSqlParserListener"; import { SparkSqlParserVisitor } from "./SparkSqlParserVisitor"; export class SparkSqlParser extends Parser { public static readonly SEMICOLON = 1; public static readonly LEFT_PAREN = 2; public static readonly RIGHT_PAREN = 3; public static readonly COMMA = 4; public static readonly DOT = 5; public static readonly LEFT_BRACKET = 6; public static readonly RIGHT_BRACKET = 7; public static readonly KW_ADD = 8; public static readonly KW_AFTER = 9; public static readonly KW_ALL = 10; public static readonly KW_ALTER = 11; public static readonly KW_ALWAYS = 12; public static readonly KW_ANALYZE = 13; public static readonly KW_AND = 14; public static readonly KW_ANTI = 15; public static readonly KW_ANY = 16; public static readonly KW_ANY_VALUE = 17; public static readonly KW_ARCHIVE = 18; public static readonly KW_ARRAY = 19; public static readonly KW_AS = 20; public static readonly KW_ASC = 21; public static readonly KW_AT = 22; public static readonly KW_AUTHORIZATION = 23; public static readonly KW_BETWEEN = 24; public static readonly KW_BIGINT = 25; public static readonly KW_BINARY = 26; public static readonly KW_BOOLEAN = 27; public static readonly KW_BOTH = 28; public static readonly KW_BUCKET = 29; public static readonly KW_BUCKETS = 30; public static readonly KW_BY = 31; public static readonly KW_BYTE = 32; public static readonly KW_CACHE = 33; public static readonly KW_CASCADE = 34; public static readonly KW_CASE = 35; public static readonly KW_CAST = 36; public static readonly KW_CATALOG = 37; public static readonly KW_CATALOGS = 38; public static readonly KW_CHANGE = 39; public static readonly KW_CHAR = 40; public static readonly KW_CHARACTER = 41; public static readonly KW_CHECK = 42; public static readonly KW_CLEAR = 43; public static readonly KW_CLUSTER = 44; public static readonly KW_CLUSTERED = 45; public static readonly KW_CODEGEN = 46; public static readonly KW_COLLATE = 47; public static readonly KW_COLLECTION = 48; public static readonly KW_COLUMN = 49; public static readonly KW_COLUMNS = 50; public static readonly KW_COMMENT = 51; public static readonly KW_COMMIT = 52; public static readonly KW_COMPACT = 53; public static readonly KW_COMPACTIONS = 54; public static readonly KW_COMPUTE = 55; public static readonly KW_CONCATENATE = 56; public static readonly KW_CONSTRAINT = 57; public static readonly KW_COST = 58; public static readonly KW_CREATE = 59; public static readonly KW_CROSS = 60; public static readonly KW_CUBE = 61; public static readonly KW_CURRENT = 62; public static readonly KW_CURRENT_DATE = 63; public static readonly KW_CURRENT_TIME = 64; public static readonly KW_CURRENT_TIMESTAMP = 65; public static readonly KW_CURRENT_USER = 66; public static readonly KW_DAY = 67; public static readonly KW_DAYS = 68; public static readonly KW_DAYOFYEAR = 69; public static readonly KW_DATA = 70; public static readonly KW_DATE = 71; public static readonly KW_DATABASE = 72; public static readonly KW_DATABASES = 73; public static readonly KW_DATEADD = 74; public static readonly KW_DATE_ADD = 75; public static readonly KW_DATEDIFF = 76; public static readonly KW_DATE_DIFF = 77; public static readonly KW_DBPROPERTIES = 78; public static readonly KW_DEC = 79; public static readonly KW_DECIMAL = 80; public static readonly KW_DECLARE = 81; public static readonly KW_DEFAULT = 82; public static readonly KW_DEFINED = 83; public static readonly KW_DELETE = 84; public static readonly KW_DELIMITED = 85; public static readonly KW_DESC = 86; public static readonly KW_DESCRIBE = 87; public static readonly KW_DFS = 88; public static readonly KW_DIRECTORIES = 89; public static readonly KW_DIRECTORY = 90; public static readonly KW_DISTINCT = 91; public static readonly KW_DISTRIBUTE = 92; public static readonly KW_DIV = 93; public static readonly KW_DOUBLE = 94; public static readonly KW_DROP = 95; public static readonly KW_ELSE = 96; public static readonly KW_END = 97; public static readonly KW_ESCAPE = 98; public static readonly KW_ESCAPED = 99; public static readonly KW_EXCEPT = 100; public static readonly KW_EXCHANGE = 101; public static readonly KW_EXCLUDE = 102; public static readonly KW_EXISTS = 103; public static readonly KW_EXPLAIN = 104; public static readonly KW_EXPORT = 105; public static readonly KW_EXTENDED = 106; public static readonly KW_EXTERNAL = 107; public static readonly KW_EXTRACT = 108; public static readonly KW_FALSE = 109; public static readonly KW_FETCH = 110; public static readonly KW_FIELDS = 111; public static readonly KW_FILTER = 112; public static readonly KW_FILEFORMAT = 113; public static readonly KW_FIRST = 114; public static readonly KW_FLOAT = 115; public static readonly KW_FOLLOWING = 116; public static readonly KW_FOR = 117; public static readonly KW_FOREIGN = 118; public static readonly KW_FORMAT = 119; public static readonly KW_FORMATTED = 120; public static readonly KW_FROM = 121; public static readonly KW_FULL = 122; public static readonly KW_FUNCTION = 123; public static readonly KW_FUNCTIONS = 124; public static readonly KW_GENERATED = 125; public static readonly KW_GLOBAL = 126; public static readonly KW_GRANT = 127; public static readonly KW_GROUP = 128; public static readonly KW_GROUPING = 129; public static readonly KW_HAVING = 130; public static readonly KW_BINARY_HEX = 131; public static readonly KW_HOUR = 132; public static readonly KW_HOURS = 133; public static readonly KW_IDENTIFIER_KW = 134; public static readonly KW_IF = 135; public static readonly KW_IGNORE = 136; public static readonly KW_IMPORT = 137; public static readonly KW_IN = 138; public static readonly KW_INCLUDE = 139; public static readonly KW_INDEX = 140; public static readonly KW_INDEXES = 141; public static readonly KW_INNER = 142; public static readonly KW_INPATH = 143; public static readonly KW_INPUTFORMAT = 144; public static readonly KW_INSERT = 145; public static readonly KW_INTERSECT = 146; public static readonly KW_INTERVAL = 147; public static readonly KW_INT = 148; public static readonly KW_INTEGER = 149; public static readonly KW_INTO = 150; public static readonly KW_IS = 151; public static readonly KW_ITEMS = 152; public static readonly KW_JOIN = 153; public static readonly KW_KEYS = 154; public static readonly KW_LAST = 155; public static readonly KW_LATERAL = 156; public static readonly KW_LAZY = 157; public static readonly KW_LEADING = 158; public static readonly KW_LEFT = 159; public static readonly KW_LIKE = 160; public static readonly KW_ILIKE = 161; public static readonly KW_LIMIT = 162; public static readonly KW_LINES = 163; public static readonly KW_LIST = 164; public static readonly KW_LOAD = 165; public static readonly KW_LOCAL = 166; public static readonly KW_LOCATION = 167; public static readonly KW_LOCK = 168; public static readonly KW_LOCKS = 169; public static readonly KW_LOGICAL = 170; public static readonly KW_LONG = 171; public static readonly KW_MACRO = 172; public static readonly KW_MAP = 173; public static readonly KW_MATCHED = 174; public static readonly KW_MERGE = 175; public static readonly KW_MICROSECOND = 176; public static readonly KW_MICROSECONDS = 177; public static readonly KW_MILLISECOND = 178; public static readonly KW_MILLISECONDS = 179; public static readonly KW_MINUTE = 180; public static readonly KW_MINUTES = 181; public static readonly KW_MONTH = 182; public static readonly KW_MONTHS = 183; public static readonly KW_MSCK = 184; public static readonly KW_NAME = 185; public static readonly KW_NAMESPACE = 186; public static readonly KW_NAMESPACES = 187; public static readonly KW_NANOSECOND = 188; public static readonly KW_NANOSECONDS = 189; public static readonly KW_NATURAL = 190; public static readonly KW_NO = 191; public static readonly KW_NOT = 192; public static readonly KW_NULL = 193; public static readonly KW_NULLS = 194; public static readonly KW_NUMERIC = 195; public static readonly KW_OF = 196; public static readonly KW_OFFSET = 197; public static readonly KW_ON = 198; public static readonly KW_ONLY = 199; public static readonly KW_OPTION = 200; public static readonly KW_OPTIONS = 201; public static readonly KW_OR = 202; public static readonly KW_ORDER = 203; public static readonly KW_OUT = 204; public static readonly KW_OUTER = 205; public static readonly KW_OUTPUTFORMAT = 206; public static readonly KW_OVER = 207; public static readonly KW_OVERLAPS = 208; public static readonly KW_OVERLAY = 209; public static readonly KW_OVERWRITE = 210; public static readonly KW_PARTITION = 211; public static readonly KW_PARTITIONED = 212; public static readonly KW_PARTITIONS = 213; public static readonly KW_PERCENTILE_CONT = 214; public static readonly KW_PERCENTILE_DISC = 215; public static readonly KW_PERCENTLIT = 216; public static readonly KW_PIVOT = 217; public static readonly KW_PLACING = 218; public static readonly KW_POSITION = 219; public static readonly KW_PRECEDING = 220; public static readonly KW_PRIMARY = 221; public static readonly KW_PRINCIPALS = 222; public static readonly KW_PROPERTIES = 223; public static readonly KW_PURGE = 224; public static readonly KW_QUARTER = 225; public static readonly KW_QUERY = 226; public static readonly KW_RANGE = 227; public static readonly KW_REAL = 228; public static readonly KW_RECORDREADER = 229; public static readonly KW_RECORDWRITER = 230; public static readonly KW_RECOVER = 231; public static readonly KW_REDUCE = 232; public static readonly KW_REFERENCES = 233; public static readonly KW_REFRESH = 234; public static readonly KW_RENAME = 235; public static readonly KW_REPAIR = 236; public static readonly KW_REPEATABLE = 237; public static readonly KW_REPLACE = 238; public static readonly KW_RESET = 239; public static readonly KW_RESPECT = 240; public static readonly KW_RESTRICT = 241; public static readonly KW_REVOKE = 242; public static readonly KW_RIGHT = 243; public static readonly KW_RLIKE = 244; public static readonly KW_REGEXP = 245; public static readonly KW_ROLE = 246; public static readonly KW_ROLES = 247; public static readonly KW_ROLLBACK = 248; public static readonly KW_ROLLUP = 249; public static readonly KW_ROW = 250; public static readonly KW_ROWS = 251; public static readonly KW_SECOND = 252; public static readonly KW_SECONDS = 253; public static readonly KW_SCHEMA = 254; public static readonly KW_SCHEMAS = 255; public static readonly KW_SELECT = 256; public static readonly KW_SEMI = 257; public static readonly KW_SEPARATED = 258; public static readonly KW_SERDE = 259; public static readonly KW_SERDEPROPERTIES = 260; public static readonly KW_SESSION_USER = 261; public static readonly KW_SET = 262; public static readonly KW_SETMINUS = 263; public static readonly KW_SETS = 264; public static readonly KW_SHORT = 265; public static readonly KW_SHOW = 266; public static readonly KW_SINGLE = 267; public static readonly KW_SKEWED = 268; public static readonly KW_SMALLINT = 269; public static readonly KW_SOME = 270; public static readonly KW_SORT = 271; public static readonly KW_SORTED = 272; public static readonly KW_SOURCE = 273; public static readonly KW_START = 274; public static readonly KW_STATISTICS = 275; public static readonly KW_STORED = 276; public static readonly KW_STRATIFY = 277; public static readonly KW_STRING = 278; public static readonly KW_STRUCT = 279; public static readonly KW_SUBSTR = 280; public static readonly KW_SUBSTRING = 281; public static readonly KW_SYNC = 282; public static readonly KW_SYSTEM = 283; public static readonly KW_SYSTEM_TIME = 284; public static readonly KW_SYSTEM_VERSION = 285; public static readonly KW_TABLE = 286; public static readonly KW_TABLES = 287; public static readonly KW_TABLESAMPLE = 288; public static readonly KW_TARGET = 289; public static readonly KW_TBLPROPERTIES = 290; public static readonly KW_TEMPORARY = 291; public static readonly KW_TERMINATED = 292; public static readonly KW_THEN = 293; public static readonly KW_TIME = 294; public static readonly KW_TIMEDIFF = 295; public static readonly KW_TIMESTAMP = 296; public static readonly KW_TIMESTAMP_LTZ = 297; public static readonly KW_TIMESTAMP_NTZ = 298; public static readonly KW_TIMESTAMPADD = 299; public static readonly KW_TIMESTAMPDIFF = 300; public static readonly KW_TINYINT = 301; public static readonly KW_TO = 302; public static readonly KW_TOUCH = 303; public static readonly KW_TRAILING = 304; public static readonly KW_TRANSACTION = 305; public static readonly KW_TRANSACTIONS = 306; public static readonly KW_TRANSFORM = 307; public static readonly KW_TRIM = 308; public static readonly KW_TRUE = 309; public static readonly KW_TRUNCATE = 310; public static readonly KW_TRY_CAST = 311; public static readonly KW_TYPE = 312; public static readonly KW_UNARCHIVE = 313; public static readonly KW_UNBOUNDED = 314; public static readonly KW_UNCACHE = 315; public static readonly KW_UNION = 316; public static readonly KW_UNIQUE = 317; public static readonly KW_UNKNOWN = 318; public static readonly KW_UNLOCK = 319; public static readonly KW_UNPIVOT = 320; public static readonly KW_UNSET = 321; public static readonly KW_UPDATE = 322; public static readonly KW_USE = 323; public static readonly KW_USER = 324; public static readonly KW_USING = 325; public static readonly KW_VALUES = 326; public static readonly KW_VARCHAR = 327; public static readonly KW_VAR = 328; public static readonly KW_VARIABLE = 329; public static readonly KW_VERSION = 330; public static readonly KW_VIEW = 331; public static readonly KW_VIEWS = 332; public static readonly KW_VOID = 333; public static readonly KW_WEEK = 334; public static readonly KW_WEEKS = 335; public static readonly KW_WHEN = 336; public static readonly KW_WHERE = 337; public static readonly KW_WINDOW = 338; public static readonly KW_WITH = 339; public static readonly KW_WITHIN = 340; public static readonly KW_YEAR = 341; public static readonly KW_YEARS = 342; public static readonly KW_ZONE = 343; public static readonly EQ = 344; public static readonly NSEQ = 345; public static readonly NEQ = 346; public static readonly NEQJ = 347; public static readonly LT = 348; public static readonly LTE = 349; public static readonly GT = 350; public static readonly GTE = 351; public static readonly NOT = 352; public static readonly PLUS = 353; public static readonly MINUS = 354; public static readonly ASTERISK = 355; public static readonly SLASH = 356; public static readonly PERCENT = 357; public static readonly TILDE = 358; public static readonly AMPERSAND = 359; public static readonly PIPE = 360; public static readonly CONCAT_PIPE = 361; public static readonly HAT = 362; public static readonly COLON = 363; public static readonly ARROW = 364; public static readonly FAT_ARROW = 365; public static readonly HENT_START = 366; public static readonly HENT_END = 367; public static readonly QUESTION = 368; public static readonly STRING_LITERAL = 369; public static readonly DOUBLEQUOTED_STRING = 370; public static readonly BIGINT_LITERAL = 371; public static readonly SMALLINT_LITERAL = 372; public static readonly TINYINT_LITERAL = 373; public static readonly INTEGER_VALUE = 374; public static readonly EXPONENT_VALUE = 375; public static readonly DECIMAL_VALUE = 376; public static readonly FLOAT_LITERAL = 377; public static readonly DOUBLE_LITERAL = 378; public static readonly BIGDECIMAL_LITERAL = 379; public static readonly IDENTIFIER = 380; public static readonly BACKQUOTED_IDENTIFIER = 381; public static readonly SIMPLE_COMMENT = 382; public static readonly BRACKETED_COMMENT = 383; public static readonly WS = 384; public static readonly UNRECOGNIZED = 385; public static readonly RULE_program = 0; public static readonly RULE_singleStatement = 1; public static readonly RULE_statement = 2; public static readonly RULE_timezone = 3; public static readonly RULE_configKey = 4; public static readonly RULE_configValue = 5; public static readonly RULE_unsupportedHiveNativeCommands = 6; public static readonly RULE_createTableHeader = 7; public static readonly RULE_replaceTableHeader = 8; public static readonly RULE_bucketSpec = 9; public static readonly RULE_skewSpec = 10; public static readonly RULE_locationSpec = 11; public static readonly RULE_commentSpec = 12; public static readonly RULE_query = 13; public static readonly RULE_insertInto = 14; public static readonly RULE_partitionSpecLocation = 15; public static readonly RULE_partitionSpec = 16; public static readonly RULE_partitionVal = 17; public static readonly RULE_dbSchema = 18; public static readonly RULE_dbSchemas = 19; public static readonly RULE_describeFuncName = 20; public static readonly RULE_describeColName = 21; public static readonly RULE_ctes = 22; public static readonly RULE_namedQuery = 23; public static readonly RULE_tableProvider = 24; public static readonly RULE_createTableClauses = 25; public static readonly RULE_propertyList = 26; public static readonly RULE_property = 27; public static readonly RULE_propertyKey = 28; public static readonly RULE_propertyValue = 29; public static readonly RULE_expressionPropertyList = 30; public static readonly RULE_expressionProperty = 31; public static readonly RULE_constantList = 32; public static readonly RULE_nestedConstantList = 33; public static readonly RULE_createFileFormat = 34; public static readonly RULE_fileFormat = 35; public static readonly RULE_storageHandler = 36; public static readonly RULE_resource = 37; public static readonly RULE_dmlStatementNoWith = 38; public static readonly RULE_dbSchemaName = 39; public static readonly RULE_dbSchemaNameCreate = 40; public static readonly RULE_tableNameCreate = 41; public static readonly RULE_tableName = 42; public static readonly RULE_viewNameCreate = 43; public static readonly RULE_viewName = 44; public static readonly RULE_identifierReference = 45; public static readonly RULE_queryOrganization = 46; public static readonly RULE_multiInsertQueryBody = 47; public static readonly RULE_queryTerm = 48; public static readonly RULE_queryPrimary = 49; public static readonly RULE_sortItem = 50; public static readonly RULE_fromStatement = 51; public static readonly RULE_fromStatementBody = 52; public static readonly RULE_querySpecification = 53; public static readonly RULE_transformClause = 54; public static readonly RULE_selectClause = 55; public static readonly RULE_setClause = 56; public static readonly RULE_matchedClause = 57; public static readonly RULE_notMatchedClause = 58; public static readonly RULE_notMatchedBySourceClause = 59; public static readonly RULE_matchedAction = 60; public static readonly RULE_notMatchedAction = 61; public static readonly RULE_notMatchedBySourceAction = 62; public static readonly RULE_assignmentList = 63; public static readonly RULE_assignment = 64; public static readonly RULE_whereClause = 65; public static readonly RULE_havingClause = 66; public static readonly RULE_hint = 67; public static readonly RULE_hintStatement = 68; public static readonly RULE_fromClause = 69; public static readonly RULE_functionKind = 70; public static readonly RULE_temporalClause = 71; public static readonly RULE_aggregationClause = 72; public static readonly RULE_groupByClause = 73; public static readonly RULE_groupingAnalytics = 74; public static readonly RULE_groupingElement = 75; public static readonly RULE_groupingSet = 76; public static readonly RULE_pivotClause = 77; public static readonly RULE_pivotColumn = 78; public static readonly RULE_pivotValue = 79; public static readonly RULE_unpivotClause = 80; public static readonly RULE_unpivotNullClause = 81; public static readonly RULE_unpivotOperator = 82; public static readonly RULE_unpivotSingleValueColumnClause = 83; public static readonly RULE_unpivotMultiValueColumnClause = 84; public static readonly RULE_unpivotColumnSet = 85; public static readonly RULE_unpivotValueColumn = 86; public static readonly RULE_unpivotNameColumn = 87; public static readonly RULE_unpivotColumnAndAlias = 88; public static readonly RULE_unpivotColumn = 89; public static readonly RULE_unpivotAlias = 90; public static readonly RULE_ifNotExists = 91; public static readonly RULE_ifExists = 92; public static readonly RULE_lateralView = 93; public static readonly RULE_setQuantifier = 94; public static readonly RULE_relation = 95; public static readonly RULE_relationExtension = 96; public static readonly RULE_joinRelation = 97; public static readonly RULE_joinType = 98; public static readonly RULE_joinCriteria = 99; public static readonly RULE_sample = 100; public static readonly RULE_sampleMethod = 101; public static readonly RULE_identifierList = 102; public static readonly RULE_identifierSeq = 103; public static readonly RULE_orderedIdentifierList = 104; public static readonly RULE_orderedIdentifier = 105; public static readonly RULE_identifierCommentList = 106; public static readonly RULE_identifierComment = 107; public static readonly RULE_relationPrimary = 108; public static readonly RULE_inlineTable = 109; public static readonly RULE_functionTableSubqueryArgument = 110; public static readonly RULE_tableArgumentPartitioning = 111; public static readonly RULE_functionTableNamedArgumentExpression = 112; public static readonly RULE_functionTableReferenceArgument = 113; public static readonly RULE_functionTableArgument = 114; public static readonly RULE_functionTable = 115; public static readonly RULE_tableAlias = 116; public static readonly RULE_rowFormat = 117; public static readonly RULE_multipartIdentifierList = 118; public static readonly RULE_multipartIdentifier = 119; public static readonly RULE_multipartIdentifierPropertyList = 120; public static readonly RULE_multipartIdentifierProperty = 121; public static readonly RULE_tableIdentifier = 122; public static readonly RULE_viewIdentifier = 123; public static readonly RULE_namedExpression = 124; public static readonly RULE_namedExpressionSeq = 125; public static readonly RULE_partitionFieldList = 126; public static readonly RULE_partitionField = 127; public static readonly RULE_transform = 128; public static readonly RULE_transformArgument = 129; public static readonly RULE_expression = 130; public static readonly RULE_namedArgumentExpression = 131; public static readonly RULE_functionArgument = 132; public static readonly RULE_expressionSeq = 133; public static readonly RULE_booleanExpression = 134; public static readonly RULE_predicate = 135; public static readonly RULE_valueExpression = 136; public static readonly RULE_datetimeUnit = 137; public static readonly RULE_primaryExpression = 138; public static readonly RULE_literalType = 139; public static readonly RULE_constant = 140; public static readonly RULE_comparisonOperator = 141; public static readonly RULE_arithmeticOperator = 142; public static readonly RULE_predicateOperator = 143; public static readonly RULE_booleanValue = 144; public static readonly RULE_interval = 145; public static readonly RULE_errorCapturingMultiUnitsInterval = 146; public static readonly RULE_multiUnitsInterval = 147; public static readonly RULE_errorCapturingUnitToUnitInterval = 148; public static readonly RULE_unitToUnitInterval = 149; public static readonly RULE_intervalValue = 150; public static readonly RULE_unitInMultiUnits = 151; public static readonly RULE_unitInUnitToUnit = 152; public static readonly RULE_colPosition = 153; public static readonly RULE_type = 154; public static readonly RULE_dataType = 155; public static readonly RULE_qualifiedColTypeWithPositionList = 156; public static readonly RULE_qualifiedColTypeWithPosition = 157; public static readonly RULE_colDefinitionDescriptorWithPosition = 158; public static readonly RULE_defaultExpression = 159; public static readonly RULE_variableDefaultExpression = 160; public static readonly RULE_colTypeList = 161; public static readonly RULE_colType = 162; public static readonly RULE_createOrReplaceTableColTypeList = 163; public static readonly RULE_createOrReplaceTableColType = 164; public static readonly RULE_colDefinitionOption = 165; public static readonly RULE_generationExpression = 166; public static readonly RULE_complexColTypeList = 167; public static readonly RULE_complexColType = 168; public static readonly RULE_whenClause = 169; public static readonly RULE_windowClause = 170; public static readonly RULE_namedWindow = 171; public static readonly RULE_windowSpec = 172; public static readonly RULE_windowFrame = 173; public static readonly RULE_frameBound = 174; public static readonly RULE_qualifiedNameList = 175; public static readonly RULE_functionName = 176; public static readonly RULE_functionNameCreate = 177; public static readonly RULE_qualifiedName = 178; public static readonly RULE_errorCapturingIdentifier = 179; public static readonly RULE_errorCapturingIdentifierExtra = 180; public static readonly RULE_identifier = 181; public static readonly RULE_strictIdentifier = 182; public static readonly RULE_quotedIdentifier = 183; public static readonly RULE_backQuotedIdentifier = 184; public static readonly RULE_number = 185; public static readonly RULE_alterColumnAction = 186; public static readonly RULE_stringLit = 187; public static readonly RULE_comment = 188; public static readonly RULE_version = 189; public static readonly RULE_ansiNonReserved = 190; public static readonly RULE_strictNonReserved = 191; public static readonly RULE_nonReserved = 192; // tslint:disable:no-trailing-whitespace public static readonly ruleNames: string[] = [ "program", "singleStatement", "statement", "timezone", "configKey", "configValue", "unsupportedHiveNativeCommands", "createTableHeader", "replaceTableHeader", "bucketSpec", "skewSpec", "locationSpec", "commentSpec", "query", "insertInto", "partitionSpecLocation", "partitionSpec", "partitionVal", "dbSchema", "dbSchemas", "describeFuncName", "describeColName", "ctes", "namedQuery", "tableProvider", "createTableClauses", "propertyList", "property", "propertyKey", "propertyValue", "expressionPropertyList", "expressionProperty", "constantList", "nestedConstantList", "createFileFormat", "fileFormat", "storageHandler", "resource", "dmlStatementNoWith", "dbSchemaName", "dbSchemaNameCreate", "tableNameCreate", "tableName", "viewNameCreate", "viewName", "identifierReference", "queryOrganization", "multiInsertQueryBody", "queryTerm", "queryPrimary", "sortItem", "fromStatement", "fromStatementBody", "querySpecification", "transformClause", "selectClause", "setClause", "matchedClause", "notMatchedClause", "notMatchedBySourceClause", "matchedAction", "notMatchedAction", "notMatchedBySourceAction", "assignmentList", "assignment", "whereClause", "havingClause", "hint", "hintStatement", "fromClause", "functionKind", "temporalClause", "aggregationClause", "groupByClause", "groupingAnalytics", "groupingElement", "groupingSet", "pivotClause", "pivotColumn", "pivotValue", "unpivotClause", "unpivotNullClause", "unpivotOperator", "unpivotSingleValueColumnClause", "unpivotMultiValueColumnClause", "unpivotColumnSet", "unpivotValueColumn", "unpivotNameColumn", "unpivotColumnAndAlias", "unpivotColumn", "unpivotAlias", "ifNotExists", "ifExists", "lateralView", "setQuantifier", "relation", "relationExtension", "joinRelation", "joinType", "joinCriteria", "sample", "sampleMethod", "identifierList", "identifierSeq", "orderedIdentifierList", "orderedIdentifier", "identifierCommentList", "identifierComment", "relationPrimary", "inlineTable", "functionTableSubqueryArgument", "tableArgumentPartitioning", "functionTableNamedArgumentExpression", "functionTableReferenceArgument", "functionTableArgument", "functionTable", "tableAlias", "rowFormat", "multipartIdentifierList", "multipartIdentifier", "multipartIdentifierPropertyList", "multipartIdentifierProperty", "tableIdentifier", "viewIdentifier", "namedExpression", "namedExpressionSeq", "partitionFieldList", "partitionField", "transform", "transformArgument", "expression", "namedArgumentExpression", "functionArgument", "expressionSeq", "booleanExpression", "predicate", "valueExpression", "datetimeUnit", "primaryExpression", "literalType", "constant", "comparisonOperator", "arithmeticOperator", "predicateOperator", "booleanValue", "interval", "errorCapturingMultiUnitsInterval", "multiUnitsInterval", "errorCapturingUnitToUnitInterval", "unitToUnitInterval", "intervalValue", "unitInMultiUnits", "unitInUnitToUnit", "colPosition", "type", "dataType", "qualifiedColTypeWithPositionList", "qualifiedColTypeWithPosition", "colDefinitionDescriptorWithPosition", "defaultExpression", "variableDefaultExpression", "colTypeList", "colType", "createOrReplaceTableColTypeList", "createOrReplaceTableColType", "colDefinitionOption", "generationExpression", "complexColTypeList", "complexColType", "whenClause", "windowClause", "namedWindow", "windowSpec", "windowFrame", "frameBound", "qualifiedNameList", "functionName", "functionNameCreate", "qualifiedName", "errorCapturingIdentifier", "errorCapturingIdentifierExtra", "identifier", "strictIdentifier", "quotedIdentifier", "backQuotedIdentifier", "number", "alterColumnAction", "stringLit", "comment", "version", "ansiNonReserved", "strictNonReserved", "nonReserved", ]; private static readonly _LITERAL_NAMES: Array = [ undefined, "';'", "'('", "')'", "','", "'.'", "'['", "']'", "'ADD'", "'AFTER'", "'ALL'", "'ALTER'", "'ALWAYS'", "'ANALYZE'", "'AND'", "'ANTI'", "'ANY'", "'ANY_VALUE'", "'ARCHIVE'", "'ARRAY'", "'AS'", "'ASC'", "'AT'", "'AUTHORIZATION'", "'BETWEEN'", "'BIGINT'", "'BINARY'", "'BOOLEAN'", "'BOTH'", "'BUCKET'", "'BUCKETS'", "'BY'", "'BYTE'", "'CACHE'", "'CASCADE'", "'CASE'", "'CAST'", "'CATALOG'", "'CATALOGS'", "'CHANGE'", "'CHAR'", "'CHARACTER'", "'CHECK'", "'CLEAR'", "'CLUSTER'", "'CLUSTERED'", "'CODEGEN'", "'COLLATE'", "'COLLECTION'", "'COLUMN'", "'COLUMNS'", "'COMMENT'", "'COMMIT'", "'COMPACT'", "'COMPACTIONS'", "'COMPUTE'", "'CONCATENATE'", "'CONSTRAINT'", "'COST'", "'CREATE'", "'CROSS'", "'CUBE'", "'CURRENT'", "'CURRENT_DATE'", "'CURRENT_TIME'", "'CURRENT_TIMESTAMP'", "'CURRENT_USER'", "'DAY'", "'DAYS'", "'DAYOFYEAR'", "'DATA'", "'DATE'", "'DATABASE'", "'DATABASES'", "'DATEADD'", "'DATE_ADD'", "'DATEDIFF'", "'DATE_DIFF'", "'DBPROPERTIES'", "'DEC'", "'DECIMAL'", "'DECLARE'", "'DEFAULT'", "'DEFINED'", "'DELETE'", "'DELIMITED'", "'DESC'", "'DESCRIBE'", "'DFS'", "'DIRECTORIES'", "'DIRECTORY'", "'DISTINCT'", "'DISTRIBUTE'", "'DIV'", "'DOUBLE'", "'DROP'", "'ELSE'", "'END'", "'ESCAPE'", "'ESCAPED'", "'EXCEPT'", "'EXCHANGE'", "'EXCLUDE'", "'EXISTS'", "'EXPLAIN'", "'EXPORT'", "'EXTENDED'", "'EXTERNAL'", "'EXTRACT'", "'FALSE'", "'FETCH'", "'FIELDS'", "'FILTER'", "'FILEFORMAT'", "'FIRST'", "'FLOAT'", "'FOLLOWING'", "'FOR'", "'FOREIGN'", "'FORMAT'", "'FORMATTED'", "'FROM'", "'FULL'", "'FUNCTION'", "'FUNCTIONS'", "'GENERATED'", "'GLOBAL'", "'GRANT'", "'GROUP'", "'GROUPING'", "'HAVING'", "'X'", "'HOUR'", "'HOURS'", "'IDENTIFIER'", "'IF'", "'IGNORE'", "'IMPORT'", "'IN'", "'INCLUDE'", "'INDEX'", "'INDEXES'", "'INNER'", "'INPATH'", "'INPUTFORMAT'", "'INSERT'", "'INTERSECT'", "'INTERVAL'", "'INT'", "'INTEGER'", "'INTO'", "'IS'", "'ITEMS'", "'JOIN'", "'KEYS'", "'LAST'", "'LATERAL'", "'LAZY'", "'LEADING'", "'LEFT'", "'LIKE'", "'ILIKE'", "'LIMIT'", "'LINES'", "'LIST'", "'LOAD'", "'LOCAL'", "'LOCATION'", "'LOCK'", "'LOCKS'", "'LOGICAL'", "'LONG'", "'MACRO'", "'MAP'", "'MATCHED'", "'MERGE'", "'MICROSECOND'", "'MICROSECONDS'", "'MILLISECOND'", "'MILLISECONDS'", "'MINUTE'", "'MINUTES'", "'MONTH'", "'MONTHS'", "'MSCK'", "'NAME'", "'NAMESPACE'", "'NAMESPACES'", "'NANOSECOND'", "'NANOSECONDS'", "'NATURAL'", "'NO'", "'NOT'", "'NULL'", "'NULLS'", "'NUMERIC'", "'OF'", "'OFFSET'", "'ON'", "'ONLY'", "'OPTION'", "'OPTIONS'", "'OR'", "'ORDER'", "'OUT'", "'OUTER'", "'OUTPUTFORMAT'", "'OVER'", "'OVERLAPS'", "'OVERLAY'", "'OVERWRITE'", "'PARTITION'", "'PARTITIONED'", "'PARTITIONS'", "'PERCENTILE_CONT'", "'PERCENTILE_DISC'", "'PERCENT'", "'PIVOT'", "'PLACING'", "'POSITION'", "'PRECEDING'", "'PRIMARY'", "'PRINCIPALS'", "'PROPERTIES'", "'PURGE'", "'QUARTER'", "'QUERY'", "'RANGE'", "'REAL'", "'RECORDREADER'", "'RECORDWRITER'", "'RECOVER'", "'REDUCE'", "'REFERENCES'", "'REFRESH'", "'RENAME'", "'REPAIR'", "'REPEATABLE'", "'REPLACE'", "'RESET'", "'RESPECT'", "'RESTRICT'", "'REVOKE'", "'RIGHT'", "'RLIKE'", "'REGEXP'", "'ROLE'", "'ROLES'", "'ROLLBACK'", "'ROLLUP'", "'ROW'", "'ROWS'", "'SECOND'", "'SECONDS'", "'SCHEMA'", "'SCHEMAS'", "'SELECT'", "'SEMI'", "'SEPARATED'", "'SERDE'", "'SERDEPROPERTIES'", "'SESSION_USER'", "'SET'", "'MINUS'", "'SETS'", "'SHORT'", "'SHOW'", "'SINGLE'", "'SKEWED'", "'SMALLINT'", "'SOME'", "'SORT'", "'SORTED'", "'SOURCE'", "'START'", "'STATISTICS'", "'STORED'", "'STRATIFY'", "'STRING'", "'STRUCT'", "'SUBSTR'", "'SUBSTRING'", "'SYNC'", "'SYSTEM'", "'SYSTEM_TIME'", "'SYSTEM_VERSION'", "'TABLE'", "'TABLES'", "'TABLESAMPLE'", "'TARGET'", "'TBLPROPERTIES'", "'TEMPORARY'", "'TERMINATED'", "'THEN'", "'TIME'", "'TIMEDIFF'", "'TIMESTAMP'", "'TIMESTAMP_LTZ'", "'TIMESTAMP_NTZ'", "'TIMESTAMPADD'", "'TIMESTAMPDIFF'", "'TINYINT'", "'TO'", "'TOUCH'", "'TRAILING'", "'TRANSACTION'", "'TRANSACTIONS'", "'TRANSFORM'", "'TRIM'", "'TRUE'", "'TRUNCATE'", "'TRY_CAST'", "'TYPE'", "'UNARCHIVE'", "'UNBOUNDED'", "'UNCACHE'", "'UNION'", "'UNIQUE'", "'UNKNOWN'", "'UNLOCK'", "'UNPIVOT'", "'UNSET'", "'UPDATE'", "'USE'", "'USER'", "'USING'", "'VALUES'", "'VARCHAR'", "'VAR'", "'VARIABLE'", "'VERSION'", "'VIEW'", "'VIEWS'", "'VOID'", "'WEEK'", "'WEEKS'", "'WHEN'", "'WHERE'", "'WINDOW'", "'WITH'", "'WITHIN'", "'YEAR'", "'YEARS'", "'ZONE'", undefined, "'<=>'", "'<>'", "'!='", "'<'", undefined, "'>'", undefined, "'!'", "'+'", "'-'", "'*'", "'/'", "'%'", "'~'", "'&'", "'|'", "'||'", "'^'", "':'", "'->'", "'=>'", "'/*+'", "'*/'", "'?'", ]; private static readonly _SYMBOLIC_NAMES: Array = [ undefined, "SEMICOLON", "LEFT_PAREN", "RIGHT_PAREN", "COMMA", "DOT", "LEFT_BRACKET", "RIGHT_BRACKET", "KW_ADD", "KW_AFTER", "KW_ALL", "KW_ALTER", "KW_ALWAYS", "KW_ANALYZE", "KW_AND", "KW_ANTI", "KW_ANY", "KW_ANY_VALUE", "KW_ARCHIVE", "KW_ARRAY", "KW_AS", "KW_ASC", "KW_AT", "KW_AUTHORIZATION", "KW_BETWEEN", "KW_BIGINT", "KW_BINARY", "KW_BOOLEAN", "KW_BOTH", "KW_BUCKET", "KW_BUCKETS", "KW_BY", "KW_BYTE", "KW_CACHE", "KW_CASCADE", "KW_CASE", "KW_CAST", "KW_CATALOG", "KW_CATALOGS", "KW_CHANGE", "KW_CHAR", "KW_CHARACTER", "KW_CHECK", "KW_CLEAR", "KW_CLUSTER", "KW_CLUSTERED", "KW_CODEGEN", "KW_COLLATE", "KW_COLLECTION", "KW_COLUMN", "KW_COLUMNS", "KW_COMMENT", "KW_COMMIT", "KW_COMPACT", "KW_COMPACTIONS", "KW_COMPUTE", "KW_CONCATENATE", "KW_CONSTRAINT", "KW_COST", "KW_CREATE", "KW_CROSS", "KW_CUBE", "KW_CURRENT", "KW_CURRENT_DATE", "KW_CURRENT_TIME", "KW_CURRENT_TIMESTAMP", "KW_CURRENT_USER", "KW_DAY", "KW_DAYS", "KW_DAYOFYEAR", "KW_DATA", "KW_DATE", "KW_DATABASE", "KW_DATABASES", "KW_DATEADD", "KW_DATE_ADD", "KW_DATEDIFF", "KW_DATE_DIFF", "KW_DBPROPERTIES", "KW_DEC", "KW_DECIMAL", "KW_DECLARE", "KW_DEFAULT", "KW_DEFINED", "KW_DELETE", "KW_DELIMITED", "KW_DESC", "KW_DESCRIBE", "KW_DFS", "KW_DIRECTORIES", "KW_DIRECTORY", "KW_DISTINCT", "KW_DISTRIBUTE", "KW_DIV", "KW_DOUBLE", "KW_DROP", "KW_ELSE", "KW_END", "KW_ESCAPE", "KW_ESCAPED", "KW_EXCEPT", "KW_EXCHANGE", "KW_EXCLUDE", "KW_EXISTS", "KW_EXPLAIN", "KW_EXPORT", "KW_EXTENDED", "KW_EXTERNAL", "KW_EXTRACT", "KW_FALSE", "KW_FETCH", "KW_FIELDS", "KW_FILTER", "KW_FILEFORMAT", "KW_FIRST", "KW_FLOAT", "KW_FOLLOWING", "KW_FOR", "KW_FOREIGN", "KW_FORMAT", "KW_FORMATTED", "KW_FROM", "KW_FULL", "KW_FUNCTION", "KW_FUNCTIONS", "KW_GENERATED", "KW_GLOBAL", "KW_GRANT", "KW_GROUP", "KW_GROUPING", "KW_HAVING", "KW_BINARY_HEX", "KW_HOUR", "KW_HOURS", "KW_IDENTIFIER_KW", "KW_IF", "KW_IGNORE", "KW_IMPORT", "KW_IN", "KW_INCLUDE", "KW_INDEX", "KW_INDEXES", "KW_INNER", "KW_INPATH", "KW_INPUTFORMAT", "KW_INSERT", "KW_INTERSECT", "KW_INTERVAL", "KW_INT", "KW_INTEGER", "KW_INTO", "KW_IS", "KW_ITEMS", "KW_JOIN", "KW_KEYS", "KW_LAST", "KW_LATERAL", "KW_LAZY", "KW_LEADING", "KW_LEFT", "KW_LIKE", "KW_ILIKE", "KW_LIMIT", "KW_LINES", "KW_LIST", "KW_LOAD", "KW_LOCAL", "KW_LOCATION", "KW_LOCK", "KW_LOCKS", "KW_LOGICAL", "KW_LONG", "KW_MACRO", "KW_MAP", "KW_MATCHED", "KW_MERGE", "KW_MICROSECOND", "KW_MICROSECONDS", "KW_MILLISECOND", "KW_MILLISECONDS", "KW_MINUTE", "KW_MINUTES", "KW_MONTH", "KW_MONTHS", "KW_MSCK", "KW_NAME", "KW_NAMESPACE", "KW_NAMESPACES", "KW_NANOSECOND", "KW_NANOSECONDS", "KW_NATURAL", "KW_NO", "KW_NOT", "KW_NULL", "KW_NULLS", "KW_NUMERIC", "KW_OF", "KW_OFFSET", "KW_ON", "KW_ONLY", "KW_OPTION", "KW_OPTIONS", "KW_OR", "KW_ORDER", "KW_OUT", "KW_OUTER", "KW_OUTPUTFORMAT", "KW_OVER", "KW_OVERLAPS", "KW_OVERLAY", "KW_OVERWRITE", "KW_PARTITION", "KW_PARTITIONED", "KW_PARTITIONS", "KW_PERCENTILE_CONT", "KW_PERCENTILE_DISC", "KW_PERCENTLIT", "KW_PIVOT", "KW_PLACING", "KW_POSITION", "KW_PRECEDING", "KW_PRIMARY", "KW_PRINCIPALS", "KW_PROPERTIES", "KW_PURGE", "KW_QUARTER", "KW_QUERY", "KW_RANGE", "KW_REAL", "KW_RECORDREADER", "KW_RECORDWRITER", "KW_RECOVER", "KW_REDUCE", "KW_REFERENCES", "KW_REFRESH", "KW_RENAME", "KW_REPAIR", "KW_REPEATABLE", "KW_REPLACE", "KW_RESET", "KW_RESPECT", "KW_RESTRICT", "KW_REVOKE", "KW_RIGHT", "KW_RLIKE", "KW_REGEXP", "KW_ROLE", "KW_ROLES", "KW_ROLLBACK", "KW_ROLLUP", "KW_ROW", "KW_ROWS", "KW_SECOND", "KW_SECONDS", "KW_SCHEMA", "KW_SCHEMAS", "KW_SELECT", "KW_SEMI", "KW_SEPARATED", "KW_SERDE", "KW_SERDEPROPERTIES", "KW_SESSION_USER", "KW_SET", "KW_SETMINUS", "KW_SETS", "KW_SHORT", "KW_SHOW", "KW_SINGLE", "KW_SKEWED", "KW_SMALLINT", "KW_SOME", "KW_SORT", "KW_SORTED", "KW_SOURCE", "KW_START", "KW_STATISTICS", "KW_STORED", "KW_STRATIFY", "KW_STRING", "KW_STRUCT", "KW_SUBSTR", "KW_SUBSTRING", "KW_SYNC", "KW_SYSTEM", "KW_SYSTEM_TIME", "KW_SYSTEM_VERSION", "KW_TABLE", "KW_TABLES", "KW_TABLESAMPLE", "KW_TARGET", "KW_TBLPROPERTIES", "KW_TEMPORARY", "KW_TERMINATED", "KW_THEN", "KW_TIME", "KW_TIMEDIFF", "KW_TIMESTAMP", "KW_TIMESTAMP_LTZ", "KW_TIMESTAMP_NTZ", "KW_TIMESTAMPADD", "KW_TIMESTAMPDIFF", "KW_TINYINT", "KW_TO", "KW_TOUCH", "KW_TRAILING", "KW_TRANSACTION", "KW_TRANSACTIONS", "KW_TRANSFORM", "KW_TRIM", "KW_TRUE", "KW_TRUNCATE", "KW_TRY_CAST", "KW_TYPE", "KW_UNARCHIVE", "KW_UNBOUNDED", "KW_UNCACHE", "KW_UNION", "KW_UNIQUE", "KW_UNKNOWN", "KW_UNLOCK", "KW_UNPIVOT", "KW_UNSET", "KW_UPDATE", "KW_USE", "KW_USER", "KW_USING", "KW_VALUES", "KW_VARCHAR", "KW_VAR", "KW_VARIABLE", "KW_VERSION", "KW_VIEW", "KW_VIEWS", "KW_VOID", "KW_WEEK", "KW_WEEKS", "KW_WHEN", "KW_WHERE", "KW_WINDOW", "KW_WITH", "KW_WITHIN", "KW_YEAR", "KW_YEARS", "KW_ZONE", "EQ", "NSEQ", "NEQ", "NEQJ", "LT", "LTE", "GT", "GTE", "NOT", "PLUS", "MINUS", "ASTERISK", "SLASH", "PERCENT", "TILDE", "AMPERSAND", "PIPE", "CONCAT_PIPE", "HAT", "COLON", "ARROW", "FAT_ARROW", "HENT_START", "HENT_END", "QUESTION", "STRING_LITERAL", "DOUBLEQUOTED_STRING", "BIGINT_LITERAL", "SMALLINT_LITERAL", "TINYINT_LITERAL", "INTEGER_VALUE", "EXPONENT_VALUE", "DECIMAL_VALUE", "FLOAT_LITERAL", "DOUBLE_LITERAL", "BIGDECIMAL_LITERAL", "IDENTIFIER", "BACKQUOTED_IDENTIFIER", "SIMPLE_COMMENT", "BRACKETED_COMMENT", "WS", "UNRECOGNIZED", ]; public static readonly VOCABULARY: Vocabulary = new VocabularyImpl(SparkSqlParser._LITERAL_NAMES, SparkSqlParser._SYMBOLIC_NAMES, []); // @Override // @NotNull public get vocabulary(): Vocabulary { return SparkSqlParser.VOCABULARY; } // tslint:enable:no-trailing-whitespace // @Override public get grammarFileName(): string { return "SparkSqlParser.g4"; } // @Override public get ruleNames(): string[] { return SparkSqlParser.ruleNames; } // @Override public get serializedATN(): string { return SparkSqlParser._serializedATN; } protected createFailedPredicateException(predicate?: string, message?: string): FailedPredicateException { return new FailedPredicateException(this, predicate, message); } /** * When false, KW_INTERSECT is given the greater precedence over the other set * operations (KW_UNION, KW_EXCEPT and MINUS) as per the SQL standard. */ public legacy_setops_precedence_enabled = false; /** * When false, a literal with an exponent would be converted into * double type rather than decimal type. */ public legacy_exponent_literal_as_decimal_enabled = false; /** * When true, the behavior of keywords follows ANSI SQL standard. */ public SQL_standard_keyword_behavior = false; /** * When true, double quoted literals are identifiers rather than STRINGs. */ public double_quoted_identifiers = false; constructor(input: TokenStream) { super(input); this._interp = new ParserATNSimulator(SparkSqlParser._ATN, this); } // @RuleVersion(0) public program(): ProgramContext { let _localctx: ProgramContext = new ProgramContext(this._ctx, this.state); this.enterRule(_localctx, 0, SparkSqlParser.RULE_program); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 389; this._errHandler.sync(this); _la = this._input.LA(1); while ((((_la) & ~0x1F) === 0 && ((1 << _la) & ((1 << SparkSqlParser.LEFT_PAREN) | (1 << SparkSqlParser.KW_ADD) | (1 << SparkSqlParser.KW_ALTER) | (1 << SparkSqlParser.KW_ANALYZE))) !== 0) || ((((_la - 33)) & ~0x1F) === 0 && ((1 << (_la - 33)) & ((1 << (SparkSqlParser.KW_CACHE - 33)) | (1 << (SparkSqlParser.KW_CLEAR - 33)) | (1 << (SparkSqlParser.KW_COMMENT - 33)) | (1 << (SparkSqlParser.KW_COMMIT - 33)) | (1 << (SparkSqlParser.KW_CREATE - 33)))) !== 0) || ((((_la - 81)) & ~0x1F) === 0 && ((1 << (_la - 81)) & ((1 << (SparkSqlParser.KW_DECLARE - 81)) | (1 << (SparkSqlParser.KW_DELETE - 81)) | (1 << (SparkSqlParser.KW_DESC - 81)) | (1 << (SparkSqlParser.KW_DESCRIBE - 81)) | (1 << (SparkSqlParser.KW_DFS - 81)) | (1 << (SparkSqlParser.KW_DROP - 81)) | (1 << (SparkSqlParser.KW_EXPLAIN - 81)) | (1 << (SparkSqlParser.KW_EXPORT - 81)))) !== 0) || ((((_la - 121)) & ~0x1F) === 0 && ((1 << (_la - 121)) & ((1 << (SparkSqlParser.KW_FROM - 121)) | (1 << (SparkSqlParser.KW_GRANT - 121)) | (1 << (SparkSqlParser.KW_IMPORT - 121)) | (1 << (SparkSqlParser.KW_INSERT - 121)))) !== 0) || ((((_la - 164)) & ~0x1F) === 0 && ((1 << (_la - 164)) & ((1 << (SparkSqlParser.KW_LIST - 164)) | (1 << (SparkSqlParser.KW_LOAD - 164)) | (1 << (SparkSqlParser.KW_LOCK - 164)) | (1 << (SparkSqlParser.KW_MAP - 164)) | (1 << (SparkSqlParser.KW_MERGE - 164)) | (1 << (SparkSqlParser.KW_MSCK - 164)))) !== 0) || ((((_la - 232)) & ~0x1F) === 0 && ((1 << (_la - 232)) & ((1 << (SparkSqlParser.KW_REDUCE - 232)) | (1 << (SparkSqlParser.KW_REFRESH - 232)) | (1 << (SparkSqlParser.KW_REPAIR - 232)) | (1 << (SparkSqlParser.KW_REPLACE - 232)) | (1 << (SparkSqlParser.KW_RESET - 232)) | (1 << (SparkSqlParser.KW_REVOKE - 232)) | (1 << (SparkSqlParser.KW_ROLLBACK - 232)) | (1 << (SparkSqlParser.KW_SELECT - 232)) | (1 << (SparkSqlParser.KW_SET - 232)))) !== 0) || ((((_la - 266)) & ~0x1F) === 0 && ((1 << (_la - 266)) & ((1 << (SparkSqlParser.KW_SHOW - 266)) | (1 << (SparkSqlParser.KW_START - 266)) | (1 << (SparkSqlParser.KW_TABLE - 266)))) !== 0) || ((((_la - 310)) & ~0x1F) === 0 && ((1 << (_la - 310)) & ((1 << (SparkSqlParser.KW_TRUNCATE - 310)) | (1 << (SparkSqlParser.KW_UNCACHE - 310)) | (1 << (SparkSqlParser.KW_UNLOCK - 310)) | (1 << (SparkSqlParser.KW_UPDATE - 310)) | (1 << (SparkSqlParser.KW_USE - 310)) | (1 << (SparkSqlParser.KW_VALUES - 310)) | (1 << (SparkSqlParser.KW_WITH - 310)))) !== 0)) { { { this.state = 386; this.singleStatement(); } } this.state = 391; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 392; this.match(SparkSqlParser.EOF); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public singleStatement(): SingleStatementContext { let _localctx: SingleStatementContext = new SingleStatementContext(this._ctx, this.state); this.enterRule(_localctx, 2, SparkSqlParser.RULE_singleStatement); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 394; this.statement(); this.state = 396; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.SEMICOLON) { { this.state = 395; this.match(SparkSqlParser.SEMICOLON); } } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public statement(): StatementContext { let _localctx: StatementContext = new StatementContext(this._ctx, this.state); this.enterRule(_localctx, 4, SparkSqlParser.RULE_statement); let _la: number; try { let _alt: number; this.state = 1237; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 133, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 398; this.query(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 400; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_WITH) { { this.state = 399; this.ctes(); } } this.state = 402; this.dmlStatementNoWith(); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 403; this.match(SparkSqlParser.KW_USE); this.state = 404; this.dbSchemaName(); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 405; this.match(SparkSqlParser.KW_USE); this.state = 406; this.dbSchema(); this.state = 407; this.dbSchemaName(); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 409; this.match(SparkSqlParser.KW_SET); this.state = 410; this.match(SparkSqlParser.KW_CATALOG); this.state = 413; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 3, this._ctx) ) { case 1: { this.state = 411; this.identifier(); } break; case 2: { this.state = 412; this.stringLit(); } break; } } break; case 6: this.enterOuterAlt(_localctx, 6); { this.state = 415; this.match(SparkSqlParser.KW_CREATE); this.state = 416; this.dbSchema(); this.state = 418; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 4, this._ctx) ) { case 1: { this.state = 417; this.ifNotExists(); } break; } this.state = 420; this.dbSchemaNameCreate(); this.state = 428; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 6, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { this.state = 426; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_COMMENT: { this.state = 421; this.commentSpec(); } break; case SparkSqlParser.KW_LOCATION: { this.state = 422; this.locationSpec(); } break; case SparkSqlParser.KW_WITH: { { this.state = 423; this.match(SparkSqlParser.KW_WITH); this.state = 424; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DBPROPERTIES || _la === SparkSqlParser.KW_PROPERTIES)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 425; this.propertyList(); } } break; default: throw new NoViableAltException(this); } } } this.state = 430; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 6, this._ctx); } } break; case 7: this.enterOuterAlt(_localctx, 7); { this.state = 431; this.match(SparkSqlParser.KW_ALTER); this.state = 432; this.dbSchema(); this.state = 433; this.dbSchemaName(); this.state = 434; this.match(SparkSqlParser.KW_SET); this.state = 435; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DBPROPERTIES || _la === SparkSqlParser.KW_PROPERTIES)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 436; this.propertyList(); } break; case 8: this.enterOuterAlt(_localctx, 8); { this.state = 438; this.match(SparkSqlParser.KW_ALTER); this.state = 439; this.dbSchema(); this.state = 440; this.dbSchemaName(); this.state = 441; this.match(SparkSqlParser.KW_SET); this.state = 442; this.locationSpec(); } break; case 9: this.enterOuterAlt(_localctx, 9); { this.state = 444; this.match(SparkSqlParser.KW_DROP); this.state = 445; this.dbSchema(); this.state = 447; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 7, this._ctx) ) { case 1: { this.state = 446; this.ifExists(); } break; } this.state = 449; this.dbSchemaName(); this.state = 451; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_CASCADE || _la === SparkSqlParser.KW_RESTRICT) { { this.state = 450; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_CASCADE || _la === SparkSqlParser.KW_RESTRICT)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } } break; case 10: this.enterOuterAlt(_localctx, 10); { this.state = 453; this.match(SparkSqlParser.KW_SHOW); this.state = 454; this.dbSchemas(); this.state = 457; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 9, this._ctx) ) { case 1: { this.state = 455; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FROM || _la === SparkSqlParser.KW_IN)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 456; this.multipartIdentifier(); } break; } this.state = 463; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 11, this._ctx) ) { case 1: { this.state = 460; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 10, this._ctx) ) { case 1: { this.state = 459; this.match(SparkSqlParser.KW_LIKE); } break; } this.state = 462; _localctx._pattern = this.stringLit(); } break; } } break; case 11: this.enterOuterAlt(_localctx, 11); { this.state = 465; this.createTableHeader(); this.state = 470; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 12, this._ctx) ) { case 1: { this.state = 466; this.match(SparkSqlParser.LEFT_PAREN); this.state = 467; this.createOrReplaceTableColTypeList(); this.state = 468; this.match(SparkSqlParser.RIGHT_PAREN); } break; } this.state = 473; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_USING) { { this.state = 472; this.tableProvider(); } } this.state = 475; this.createTableClauses(); this.state = 480; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 15, this._ctx) ) { case 1: { this.state = 477; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_AS) { { this.state = 476; this.match(SparkSqlParser.KW_AS); } } this.state = 479; this.query(); } break; } } break; case 12: this.enterOuterAlt(_localctx, 12); { this.state = 482; this.match(SparkSqlParser.KW_CREATE); this.state = 483; this.match(SparkSqlParser.KW_TABLE); this.state = 485; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 16, this._ctx) ) { case 1: { this.state = 484; this.ifNotExists(); } break; } this.state = 487; _localctx._target = this.tableNameCreate(); this.state = 488; this.match(SparkSqlParser.KW_LIKE); this.state = 489; _localctx._source = this.tableName(); this.state = 498; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.KW_LOCATION || _la === SparkSqlParser.KW_ROW || _la === SparkSqlParser.KW_STORED || _la === SparkSqlParser.KW_TBLPROPERTIES || _la === SparkSqlParser.KW_USING) { { this.state = 496; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_USING: { this.state = 490; this.tableProvider(); } break; case SparkSqlParser.KW_ROW: { this.state = 491; this.rowFormat(); } break; case SparkSqlParser.KW_STORED: { this.state = 492; this.createFileFormat(); } break; case SparkSqlParser.KW_LOCATION: { this.state = 493; this.locationSpec(); } break; case SparkSqlParser.KW_TBLPROPERTIES: { { this.state = 494; this.match(SparkSqlParser.KW_TBLPROPERTIES); this.state = 495; _localctx._tableProps = this.propertyList(); } } break; default: throw new NoViableAltException(this); } } this.state = 500; this._errHandler.sync(this); _la = this._input.LA(1); } } break; case 13: this.enterOuterAlt(_localctx, 13); { this.state = 501; this.replaceTableHeader(); this.state = 506; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 19, this._ctx) ) { case 1: { this.state = 502; this.match(SparkSqlParser.LEFT_PAREN); this.state = 503; this.createOrReplaceTableColTypeList(); this.state = 504; this.match(SparkSqlParser.RIGHT_PAREN); } break; } this.state = 509; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_USING) { { this.state = 508; this.tableProvider(); } } this.state = 511; this.createTableClauses(); this.state = 516; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 22, this._ctx) ) { case 1: { this.state = 513; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_AS) { { this.state = 512; this.match(SparkSqlParser.KW_AS); } } this.state = 515; this.query(); } break; } } break; case 14: this.enterOuterAlt(_localctx, 14); { this.state = 518; this.match(SparkSqlParser.KW_ANALYZE); this.state = 519; this.match(SparkSqlParser.KW_TABLE); this.state = 520; this.tableName(); this.state = 522; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 521; this.partitionSpec(); } } this.state = 524; this.match(SparkSqlParser.KW_COMPUTE); this.state = 525; this.match(SparkSqlParser.KW_STATISTICS); this.state = 533; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 24, this._ctx) ) { case 1: { this.state = 526; this.identifier(); } break; case 2: { this.state = 527; this.match(SparkSqlParser.KW_FOR); this.state = 528; this.match(SparkSqlParser.KW_COLUMNS); this.state = 529; this.identifierSeq(); } break; case 3: { this.state = 530; this.match(SparkSqlParser.KW_FOR); this.state = 531; this.match(SparkSqlParser.KW_ALL); this.state = 532; this.match(SparkSqlParser.KW_COLUMNS); } break; } } break; case 15: this.enterOuterAlt(_localctx, 15); { this.state = 535; this.match(SparkSqlParser.KW_ANALYZE); this.state = 536; this.match(SparkSqlParser.KW_TABLES); this.state = 539; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_FROM || _la === SparkSqlParser.KW_IN) { { this.state = 537; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FROM || _la === SparkSqlParser.KW_IN)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 538; this.dbSchemaName(); } } this.state = 541; this.match(SparkSqlParser.KW_COMPUTE); this.state = 542; this.match(SparkSqlParser.KW_STATISTICS); this.state = 544; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 26, this._ctx) ) { case 1: { this.state = 543; this.identifier(); } break; } } break; case 16: this.enterOuterAlt(_localctx, 16); { this.state = 546; this.match(SparkSqlParser.KW_ALTER); this.state = 547; this.match(SparkSqlParser.KW_TABLE); this.state = 548; this.tableName(); this.state = 549; this.match(SparkSqlParser.KW_ADD); this.state = 550; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_COLUMN || _la === SparkSqlParser.KW_COLUMNS)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 551; this.qualifiedColTypeWithPositionList(); } break; case 17: this.enterOuterAlt(_localctx, 17); { this.state = 553; this.match(SparkSqlParser.KW_ALTER); this.state = 554; this.match(SparkSqlParser.KW_TABLE); this.state = 555; this.tableName(); this.state = 556; this.match(SparkSqlParser.KW_ADD); this.state = 557; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_COLUMN || _la === SparkSqlParser.KW_COLUMNS)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 558; this.match(SparkSqlParser.LEFT_PAREN); this.state = 559; this.qualifiedColTypeWithPositionList(); this.state = 560; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 18: this.enterOuterAlt(_localctx, 18); { this.state = 562; this.match(SparkSqlParser.KW_ALTER); this.state = 563; this.match(SparkSqlParser.KW_TABLE); this.state = 564; _localctx._table = this.tableName(); this.state = 565; this.match(SparkSqlParser.KW_RENAME); this.state = 566; this.match(SparkSqlParser.KW_COLUMN); this.state = 567; this.multipartIdentifier(); this.state = 568; this.match(SparkSqlParser.KW_TO); this.state = 569; this.errorCapturingIdentifier(); } break; case 19: this.enterOuterAlt(_localctx, 19); { this.state = 571; this.match(SparkSqlParser.KW_ALTER); this.state = 572; this.match(SparkSqlParser.KW_TABLE); this.state = 573; this.tableName(); this.state = 574; this.match(SparkSqlParser.KW_DROP); this.state = 575; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_COLUMN || _la === SparkSqlParser.KW_COLUMNS)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 577; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_IF) { { this.state = 576; this.ifExists(); } } this.state = 579; this.match(SparkSqlParser.LEFT_PAREN); this.state = 580; this.multipartIdentifierList(); this.state = 581; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 20: this.enterOuterAlt(_localctx, 20); { this.state = 583; this.match(SparkSqlParser.KW_ALTER); this.state = 584; this.match(SparkSqlParser.KW_TABLE); this.state = 585; this.tableName(); this.state = 586; this.match(SparkSqlParser.KW_DROP); this.state = 587; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_COLUMN || _la === SparkSqlParser.KW_COLUMNS)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 589; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 28, this._ctx) ) { case 1: { this.state = 588; this.ifExists(); } break; } this.state = 591; this.multipartIdentifierList(); } break; case 21: this.enterOuterAlt(_localctx, 21); { this.state = 593; this.match(SparkSqlParser.KW_ALTER); this.state = 598; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_TABLE: { this.state = 594; this.match(SparkSqlParser.KW_TABLE); this.state = 595; this.tableName(); } break; case SparkSqlParser.KW_VIEW: { this.state = 596; this.match(SparkSqlParser.KW_VIEW); this.state = 597; this.viewName(); } break; default: throw new NoViableAltException(this); } this.state = 600; this.match(SparkSqlParser.KW_RENAME); this.state = 601; this.match(SparkSqlParser.KW_TO); this.state = 602; this.multipartIdentifier(); } break; case 22: this.enterOuterAlt(_localctx, 22); { this.state = 604; this.match(SparkSqlParser.KW_ALTER); this.state = 609; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_TABLE: { this.state = 605; this.match(SparkSqlParser.KW_TABLE); this.state = 606; this.tableName(); } break; case SparkSqlParser.KW_VIEW: { this.state = 607; this.match(SparkSqlParser.KW_VIEW); this.state = 608; this.viewName(); } break; default: throw new NoViableAltException(this); } this.state = 611; this.match(SparkSqlParser.KW_SET); this.state = 612; this.match(SparkSqlParser.KW_TBLPROPERTIES); this.state = 613; this.propertyList(); } break; case 23: this.enterOuterAlt(_localctx, 23); { this.state = 615; this.match(SparkSqlParser.KW_ALTER); this.state = 620; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_TABLE: { this.state = 616; this.match(SparkSqlParser.KW_TABLE); this.state = 617; this.tableName(); } break; case SparkSqlParser.KW_VIEW: { this.state = 618; this.match(SparkSqlParser.KW_VIEW); this.state = 619; this.viewName(); } break; default: throw new NoViableAltException(this); } this.state = 622; this.match(SparkSqlParser.KW_UNSET); this.state = 623; this.match(SparkSqlParser.KW_TBLPROPERTIES); this.state = 625; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_IF) { { this.state = 624; this.ifExists(); } } this.state = 627; this.propertyList(); } break; case 24: this.enterOuterAlt(_localctx, 24); { this.state = 629; this.match(SparkSqlParser.KW_ALTER); this.state = 630; this.match(SparkSqlParser.KW_TABLE); this.state = 631; _localctx._table = this.tableName(); this.state = 632; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ALTER || _la === SparkSqlParser.KW_CHANGE)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 634; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 33, this._ctx) ) { case 1: { this.state = 633; this.match(SparkSqlParser.KW_COLUMN); } break; } this.state = 636; _localctx._column = this.multipartIdentifier(); this.state = 638; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 34, this._ctx) ) { case 1: { this.state = 637; this.alterColumnAction(); } break; } } break; case 25: this.enterOuterAlt(_localctx, 25); { this.state = 640; this.match(SparkSqlParser.KW_ALTER); this.state = 641; this.match(SparkSqlParser.KW_TABLE); this.state = 642; _localctx._table = this.tableName(); this.state = 644; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 643; this.partitionSpec(); } } this.state = 646; this.match(SparkSqlParser.KW_CHANGE); this.state = 648; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 36, this._ctx) ) { case 1: { this.state = 647; this.match(SparkSqlParser.KW_COLUMN); } break; } this.state = 650; _localctx._colName = this.multipartIdentifier(); this.state = 651; this.colType(); this.state = 653; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_AFTER || _la === SparkSqlParser.KW_FIRST) { { this.state = 652; this.colPosition(); } } } break; case 26: this.enterOuterAlt(_localctx, 26); { this.state = 655; this.match(SparkSqlParser.KW_ALTER); this.state = 656; this.match(SparkSqlParser.KW_TABLE); this.state = 657; _localctx._table = this.tableName(); this.state = 659; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 658; this.partitionSpec(); } } this.state = 661; this.match(SparkSqlParser.KW_REPLACE); this.state = 662; this.match(SparkSqlParser.KW_COLUMNS); this.state = 663; this.match(SparkSqlParser.LEFT_PAREN); this.state = 664; this.qualifiedColTypeWithPositionList(); this.state = 665; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 27: this.enterOuterAlt(_localctx, 27); { this.state = 667; this.match(SparkSqlParser.KW_ALTER); this.state = 668; this.match(SparkSqlParser.KW_TABLE); this.state = 669; this.tableName(); this.state = 671; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 670; this.partitionSpec(); } } this.state = 673; this.match(SparkSqlParser.KW_SET); this.state = 674; this.match(SparkSqlParser.KW_SERDE); this.state = 675; this.stringLit(); this.state = 679; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 40, this._ctx) ) { case 1: { this.state = 676; this.match(SparkSqlParser.KW_WITH); this.state = 677; this.match(SparkSqlParser.KW_SERDEPROPERTIES); this.state = 678; this.propertyList(); } break; } } break; case 28: this.enterOuterAlt(_localctx, 28); { this.state = 681; this.match(SparkSqlParser.KW_ALTER); this.state = 682; this.match(SparkSqlParser.KW_TABLE); this.state = 683; this.tableName(); this.state = 685; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 684; this.partitionSpec(); } } this.state = 687; this.match(SparkSqlParser.KW_SET); this.state = 688; this.match(SparkSqlParser.KW_SERDEPROPERTIES); this.state = 689; this.propertyList(); } break; case 29: this.enterOuterAlt(_localctx, 29); { this.state = 691; this.match(SparkSqlParser.KW_ALTER); this.state = 696; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_TABLE: { this.state = 692; this.match(SparkSqlParser.KW_TABLE); this.state = 693; this.tableName(); } break; case SparkSqlParser.KW_VIEW: { this.state = 694; this.match(SparkSqlParser.KW_VIEW); this.state = 695; this.viewName(); } break; default: throw new NoViableAltException(this); } this.state = 698; this.match(SparkSqlParser.KW_ADD); this.state = 700; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_IF) { { this.state = 699; this.ifNotExists(); } } this.state = 703; this._errHandler.sync(this); _la = this._input.LA(1); do { { { this.state = 702; this.partitionSpecLocation(); } } this.state = 705; this._errHandler.sync(this); _la = this._input.LA(1); } while (_la === SparkSqlParser.KW_PARTITION); } break; case 30: this.enterOuterAlt(_localctx, 30); { this.state = 707; this.match(SparkSqlParser.KW_ALTER); this.state = 708; this.match(SparkSqlParser.KW_TABLE); this.state = 709; this.tableName(); this.state = 710; this.partitionSpec(); this.state = 711; this.match(SparkSqlParser.KW_RENAME); this.state = 712; this.match(SparkSqlParser.KW_TO); this.state = 713; this.partitionSpec(); } break; case 31: this.enterOuterAlt(_localctx, 31); { this.state = 715; this.match(SparkSqlParser.KW_ALTER); this.state = 720; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_TABLE: { this.state = 716; this.match(SparkSqlParser.KW_TABLE); this.state = 717; this.tableName(); } break; case SparkSqlParser.KW_VIEW: { this.state = 718; this.match(SparkSqlParser.KW_VIEW); this.state = 719; this.viewName(); } break; default: throw new NoViableAltException(this); } this.state = 722; this.match(SparkSqlParser.KW_DROP); this.state = 724; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_IF) { { this.state = 723; this.ifExists(); } } this.state = 726; this.partitionSpec(); this.state = 731; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 727; this.match(SparkSqlParser.COMMA); this.state = 728; this.partitionSpec(); } } this.state = 733; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 735; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PURGE) { { this.state = 734; this.match(SparkSqlParser.KW_PURGE); } } } break; case 32: this.enterOuterAlt(_localctx, 32); { this.state = 737; this.match(SparkSqlParser.KW_ALTER); this.state = 738; this.match(SparkSqlParser.KW_TABLE); this.state = 739; this.tableName(); this.state = 741; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 740; this.partitionSpec(); } } this.state = 743; this.match(SparkSqlParser.KW_SET); this.state = 744; this.locationSpec(); } break; case 33: this.enterOuterAlt(_localctx, 33); { this.state = 746; this.match(SparkSqlParser.KW_ALTER); this.state = 747; this.match(SparkSqlParser.KW_TABLE); this.state = 748; this.tableName(); this.state = 749; this.match(SparkSqlParser.KW_RECOVER); this.state = 750; this.match(SparkSqlParser.KW_PARTITIONS); } break; case 34: this.enterOuterAlt(_localctx, 34); { this.state = 752; this.match(SparkSqlParser.KW_DROP); this.state = 753; this.match(SparkSqlParser.KW_TABLE); this.state = 755; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 50, this._ctx) ) { case 1: { this.state = 754; this.ifExists(); } break; } this.state = 757; this.tableName(); this.state = 759; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PURGE) { { this.state = 758; this.match(SparkSqlParser.KW_PURGE); } } } break; case 35: this.enterOuterAlt(_localctx, 35); { this.state = 761; this.match(SparkSqlParser.KW_DROP); this.state = 762; this.match(SparkSqlParser.KW_VIEW); this.state = 764; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 52, this._ctx) ) { case 1: { this.state = 763; this.ifExists(); } break; } this.state = 766; this.viewName(); } break; case 36: this.enterOuterAlt(_localctx, 36); { this.state = 767; this.match(SparkSqlParser.KW_CREATE); this.state = 770; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OR) { { this.state = 768; this.match(SparkSqlParser.KW_OR); this.state = 769; this.match(SparkSqlParser.KW_REPLACE); } } this.state = 776; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_GLOBAL || _la === SparkSqlParser.KW_TEMPORARY) { { this.state = 773; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_GLOBAL) { { this.state = 772; this.match(SparkSqlParser.KW_GLOBAL); } } this.state = 775; this.match(SparkSqlParser.KW_TEMPORARY); } } this.state = 778; this.match(SparkSqlParser.KW_VIEW); this.state = 780; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 56, this._ctx) ) { case 1: { this.state = 779; this.ifNotExists(); } break; } this.state = 782; this.viewNameCreate(); this.state = 784; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.LEFT_PAREN) { { this.state = 783; this.identifierCommentList(); } } this.state = 794; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.KW_COMMENT || _la === SparkSqlParser.KW_PARTITIONED || _la === SparkSqlParser.KW_TBLPROPERTIES) { { this.state = 792; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_COMMENT: { this.state = 786; this.commentSpec(); } break; case SparkSqlParser.KW_PARTITIONED: { { this.state = 787; this.match(SparkSqlParser.KW_PARTITIONED); this.state = 788; this.match(SparkSqlParser.KW_ON); this.state = 789; this.identifierList(); } } break; case SparkSqlParser.KW_TBLPROPERTIES: { { this.state = 790; this.match(SparkSqlParser.KW_TBLPROPERTIES); this.state = 791; this.propertyList(); } } break; default: throw new NoViableAltException(this); } } this.state = 796; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 797; this.match(SparkSqlParser.KW_AS); this.state = 798; this.query(); } break; case 37: this.enterOuterAlt(_localctx, 37); { this.state = 800; this.match(SparkSqlParser.KW_CREATE); this.state = 803; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OR) { { this.state = 801; this.match(SparkSqlParser.KW_OR); this.state = 802; this.match(SparkSqlParser.KW_REPLACE); } } this.state = 806; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_GLOBAL) { { this.state = 805; this.match(SparkSqlParser.KW_GLOBAL); } } this.state = 808; this.match(SparkSqlParser.KW_TEMPORARY); this.state = 809; this.match(SparkSqlParser.KW_VIEW); this.state = 810; this.viewNameCreate(); this.state = 815; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.LEFT_PAREN) { { this.state = 811; this.match(SparkSqlParser.LEFT_PAREN); this.state = 812; this.colTypeList(); this.state = 813; this.match(SparkSqlParser.RIGHT_PAREN); } } this.state = 817; this.tableProvider(); this.state = 820; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OPTIONS) { { this.state = 818; this.match(SparkSqlParser.KW_OPTIONS); this.state = 819; this.propertyList(); } } } break; case 38: this.enterOuterAlt(_localctx, 38); { this.state = 822; this.match(SparkSqlParser.KW_ALTER); this.state = 823; this.match(SparkSqlParser.KW_VIEW); this.state = 824; this.viewName(); this.state = 826; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_AS) { { this.state = 825; this.match(SparkSqlParser.KW_AS); } } this.state = 828; this.query(); } break; case 39: this.enterOuterAlt(_localctx, 39); { this.state = 830; this.match(SparkSqlParser.KW_CREATE); this.state = 833; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OR) { { this.state = 831; this.match(SparkSqlParser.KW_OR); this.state = 832; this.match(SparkSqlParser.KW_REPLACE); } } this.state = 836; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_TEMPORARY) { { this.state = 835; this.match(SparkSqlParser.KW_TEMPORARY); } } this.state = 838; this.match(SparkSqlParser.KW_FUNCTION); this.state = 840; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 67, this._ctx) ) { case 1: { this.state = 839; this.ifNotExists(); } break; } this.state = 842; this.functionNameCreate(); this.state = 843; this.match(SparkSqlParser.KW_AS); this.state = 844; _localctx._className = this.stringLit(); this.state = 854; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_USING) { { this.state = 845; this.match(SparkSqlParser.KW_USING); this.state = 846; this.resource(); this.state = 851; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 847; this.match(SparkSqlParser.COMMA); this.state = 848; this.resource(); } } this.state = 853; this._errHandler.sync(this); _la = this._input.LA(1); } } } } break; case 40: this.enterOuterAlt(_localctx, 40); { this.state = 856; this.match(SparkSqlParser.KW_DROP); this.state = 858; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_TEMPORARY) { { this.state = 857; this.match(SparkSqlParser.KW_TEMPORARY); } } this.state = 860; this.match(SparkSqlParser.KW_FUNCTION); this.state = 862; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 71, this._ctx) ) { case 1: { this.state = 861; this.ifExists(); } break; } this.state = 864; this.functionName(); } break; case 41: this.enterOuterAlt(_localctx, 41); { this.state = 865; this.match(SparkSqlParser.KW_DECLARE); this.state = 868; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 72, this._ctx) ) { case 1: { this.state = 866; this.match(SparkSqlParser.KW_OR); this.state = 867; this.match(SparkSqlParser.KW_REPLACE); } break; } this.state = 871; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 73, this._ctx) ) { case 1: { this.state = 870; this.match(SparkSqlParser.KW_VARIABLE); } break; } this.state = 873; this.functionName(); this.state = 875; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 74, this._ctx) ) { case 1: { this.state = 874; this.dataType(); } break; } this.state = 878; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_DEFAULT || _la === SparkSqlParser.EQ) { { this.state = 877; this.variableDefaultExpression(); } } } break; case 42: this.enterOuterAlt(_localctx, 42); { this.state = 880; this.match(SparkSqlParser.KW_DROP); this.state = 881; this.match(SparkSqlParser.KW_TEMPORARY); this.state = 882; this.match(SparkSqlParser.KW_VARIABLE); this.state = 884; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 76, this._ctx) ) { case 1: { this.state = 883; this.ifExists(); } break; } this.state = 889; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 77, this._ctx) ) { case 1: { this.state = 886; this.tableName(); } break; case 2: { this.state = 887; this.viewName(); } break; case 3: { this.state = 888; this.functionName(); } break; } } break; case 43: this.enterOuterAlt(_localctx, 43); { this.state = 891; this.match(SparkSqlParser.KW_EXPLAIN); this.state = 893; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_CODEGEN || _la === SparkSqlParser.KW_COST || _la === SparkSqlParser.KW_EXTENDED || _la === SparkSqlParser.KW_FORMATTED || _la === SparkSqlParser.KW_LOGICAL) { { this.state = 892; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_CODEGEN || _la === SparkSqlParser.KW_COST || _la === SparkSqlParser.KW_EXTENDED || _la === SparkSqlParser.KW_FORMATTED || _la === SparkSqlParser.KW_LOGICAL)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } this.state = 895; this.statement(); } break; case 44: this.enterOuterAlt(_localctx, 44); { this.state = 896; this.match(SparkSqlParser.KW_SHOW); this.state = 897; this.match(SparkSqlParser.KW_TABLES); this.state = 900; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 79, this._ctx) ) { case 1: { this.state = 898; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FROM || _la === SparkSqlParser.KW_IN)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 899; this.dbSchemaName(); } break; } this.state = 906; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 81, this._ctx) ) { case 1: { this.state = 903; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 80, this._ctx) ) { case 1: { this.state = 902; this.match(SparkSqlParser.KW_LIKE); } break; } this.state = 905; _localctx._pattern = this.stringLit(); } break; } } break; case 45: this.enterOuterAlt(_localctx, 45); { this.state = 908; this.match(SparkSqlParser.KW_SHOW); this.state = 909; this.match(SparkSqlParser.KW_TABLE); this.state = 910; this.match(SparkSqlParser.KW_EXTENDED); this.state = 913; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_FROM || _la === SparkSqlParser.KW_IN) { { this.state = 911; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FROM || _la === SparkSqlParser.KW_IN)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 912; _localctx._ns = this.dbSchemaName(); } } this.state = 915; this.match(SparkSqlParser.KW_LIKE); this.state = 916; _localctx._pattern = this.stringLit(); this.state = 918; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 917; this.partitionSpec(); } } } break; case 46: this.enterOuterAlt(_localctx, 46); { this.state = 920; this.match(SparkSqlParser.KW_SHOW); this.state = 921; this.match(SparkSqlParser.KW_TBLPROPERTIES); this.state = 922; _localctx._table = this.tableName(); this.state = 927; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 84, this._ctx) ) { case 1: { this.state = 923; this.match(SparkSqlParser.LEFT_PAREN); this.state = 924; _localctx._key = this.propertyKey(); this.state = 925; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } break; case 47: this.enterOuterAlt(_localctx, 47); { this.state = 929; this.match(SparkSqlParser.KW_SHOW); this.state = 930; this.match(SparkSqlParser.KW_COLUMNS); this.state = 931; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FROM || _la === SparkSqlParser.KW_IN)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 932; _localctx._table = this.tableName(); this.state = 935; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 85, this._ctx) ) { case 1: { this.state = 933; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FROM || _la === SparkSqlParser.KW_IN)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 934; this.multipartIdentifier(); } break; } } break; case 48: this.enterOuterAlt(_localctx, 48); { this.state = 937; this.match(SparkSqlParser.KW_SHOW); this.state = 938; this.match(SparkSqlParser.KW_VIEWS); this.state = 941; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 86, this._ctx) ) { case 1: { this.state = 939; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FROM || _la === SparkSqlParser.KW_IN)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 940; this.dbSchemaName(); } break; } this.state = 947; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 88, this._ctx) ) { case 1: { this.state = 944; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 87, this._ctx) ) { case 1: { this.state = 943; this.match(SparkSqlParser.KW_LIKE); } break; } this.state = 946; _localctx._pattern = this.stringLit(); } break; } } break; case 49: this.enterOuterAlt(_localctx, 49); { this.state = 949; this.match(SparkSqlParser.KW_SHOW); this.state = 950; this.match(SparkSqlParser.KW_PARTITIONS); this.state = 951; this.tableName(); this.state = 953; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 952; this.partitionSpec(); } } } break; case 50: this.enterOuterAlt(_localctx, 50); { this.state = 955; this.match(SparkSqlParser.KW_SHOW); this.state = 957; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ALL || _la === SparkSqlParser.KW_SYSTEM || _la === SparkSqlParser.KW_USER) { { this.state = 956; this.functionKind(); } } this.state = 959; this.match(SparkSqlParser.KW_FUNCTIONS); this.state = 962; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 91, this._ctx) ) { case 1: { this.state = 960; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FROM || _la === SparkSqlParser.KW_IN)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 961; _localctx._ns = this.dbSchemaName(); } break; } this.state = 971; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 94, this._ctx) ) { case 1: { this.state = 965; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 92, this._ctx) ) { case 1: { this.state = 964; this.match(SparkSqlParser.KW_LIKE); } break; } this.state = 969; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 93, this._ctx) ) { case 1: { this.state = 967; _localctx._legacy = this.multipartIdentifier(); } break; case 2: { this.state = 968; _localctx._pattern = this.stringLit(); } break; } } break; } } break; case 51: this.enterOuterAlt(_localctx, 51); { this.state = 973; this.match(SparkSqlParser.KW_SHOW); this.state = 974; this.match(SparkSqlParser.KW_CREATE); this.state = 975; this.match(SparkSqlParser.KW_TABLE); this.state = 976; this.tableName(); this.state = 979; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_AS) { { this.state = 977; this.match(SparkSqlParser.KW_AS); this.state = 978; this.match(SparkSqlParser.KW_SERDE); } } } break; case 52: this.enterOuterAlt(_localctx, 52); { this.state = 981; this.match(SparkSqlParser.KW_SHOW); this.state = 982; this.match(SparkSqlParser.KW_CURRENT); this.state = 983; this.dbSchema(); } break; case 53: this.enterOuterAlt(_localctx, 53); { this.state = 984; this.match(SparkSqlParser.KW_SHOW); this.state = 985; this.match(SparkSqlParser.KW_CATALOGS); this.state = 990; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 97, this._ctx) ) { case 1: { this.state = 987; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 96, this._ctx) ) { case 1: { this.state = 986; this.match(SparkSqlParser.KW_LIKE); } break; } this.state = 989; _localctx._pattern = this.stringLit(); } break; } } break; case 54: this.enterOuterAlt(_localctx, 54); { this.state = 992; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DESC || _la === SparkSqlParser.KW_DESCRIBE)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 993; this.match(SparkSqlParser.KW_FUNCTION); this.state = 995; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 98, this._ctx) ) { case 1: { this.state = 994; this.match(SparkSqlParser.KW_EXTENDED); } break; } this.state = 997; this.describeFuncName(); } break; case 55: this.enterOuterAlt(_localctx, 55); { this.state = 998; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DESC || _la === SparkSqlParser.KW_DESCRIBE)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 999; this.match(SparkSqlParser.KW_DATABASE); this.state = 1001; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 99, this._ctx) ) { case 1: { this.state = 1000; this.match(SparkSqlParser.KW_EXTENDED); } break; } this.state = 1003; this.dbSchemaName(); } break; case 56: this.enterOuterAlt(_localctx, 56); { this.state = 1004; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DESC || _la === SparkSqlParser.KW_DESCRIBE)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 1006; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 100, this._ctx) ) { case 1: { this.state = 1005; this.match(SparkSqlParser.KW_TABLE); } break; } this.state = 1009; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 101, this._ctx) ) { case 1: { this.state = 1008; _localctx._option = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_EXTENDED || _la === SparkSqlParser.KW_FORMATTED)) { _localctx._option = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; } this.state = 1011; this.tableName(); this.state = 1013; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 102, this._ctx) ) { case 1: { this.state = 1012; this.partitionSpec(); } break; } this.state = 1016; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 103, this._ctx) ) { case 1: { this.state = 1015; this.describeColName(); } break; } } break; case 57: this.enterOuterAlt(_localctx, 57); { this.state = 1018; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DESC || _la === SparkSqlParser.KW_DESCRIBE)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 1020; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_QUERY) { { this.state = 1019; this.match(SparkSqlParser.KW_QUERY); } } this.state = 1022; this.query(); } break; case 58: this.enterOuterAlt(_localctx, 58); { this.state = 1023; this.match(SparkSqlParser.KW_COMMENT); this.state = 1024; this.match(SparkSqlParser.KW_ON); this.state = 1025; this.dbSchema(); this.state = 1026; this.dbSchemaName(); this.state = 1027; this.match(SparkSqlParser.KW_IS); this.state = 1028; this.comment(); } break; case 59: this.enterOuterAlt(_localctx, 59); { this.state = 1030; this.match(SparkSqlParser.KW_COMMENT); this.state = 1031; this.match(SparkSqlParser.KW_ON); this.state = 1032; this.match(SparkSqlParser.KW_TABLE); this.state = 1033; this.tableName(); this.state = 1034; this.match(SparkSqlParser.KW_IS); this.state = 1035; this.comment(); } break; case 60: this.enterOuterAlt(_localctx, 60); { this.state = 1037; this.match(SparkSqlParser.KW_REFRESH); this.state = 1038; this.match(SparkSqlParser.KW_TABLE); this.state = 1039; this.tableName(); } break; case 61: this.enterOuterAlt(_localctx, 61); { this.state = 1040; this.match(SparkSqlParser.KW_REFRESH); this.state = 1041; this.match(SparkSqlParser.KW_FUNCTION); this.state = 1042; this.functionName(); } break; case 62: this.enterOuterAlt(_localctx, 62); { this.state = 1043; this.match(SparkSqlParser.KW_REFRESH); this.state = 1051; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 106, this._ctx) ) { case 1: { this.state = 1044; this.stringLit(); } break; case 2: { this.state = 1048; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 105, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 1045; this.matchWildcard(); } } } this.state = 1050; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 105, this._ctx); } } break; } } break; case 63: this.enterOuterAlt(_localctx, 63); { this.state = 1053; this.match(SparkSqlParser.KW_CACHE); this.state = 1055; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_LAZY) { { this.state = 1054; this.match(SparkSqlParser.KW_LAZY); } } this.state = 1057; this.match(SparkSqlParser.KW_TABLE); this.state = 1058; this.tableName(); this.state = 1061; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OPTIONS) { { this.state = 1059; this.match(SparkSqlParser.KW_OPTIONS); this.state = 1060; _localctx._options = this.propertyList(); } } this.state = 1067; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 110, this._ctx) ) { case 1: { this.state = 1064; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_AS) { { this.state = 1063; this.match(SparkSqlParser.KW_AS); } } this.state = 1066; this.query(); } break; } } break; case 64: this.enterOuterAlt(_localctx, 64); { this.state = 1069; this.match(SparkSqlParser.KW_UNCACHE); this.state = 1070; this.match(SparkSqlParser.KW_TABLE); this.state = 1072; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 111, this._ctx) ) { case 1: { this.state = 1071; this.ifExists(); } break; } this.state = 1074; this.tableName(); } break; case 65: this.enterOuterAlt(_localctx, 65); { this.state = 1075; this.match(SparkSqlParser.KW_CLEAR); this.state = 1076; this.match(SparkSqlParser.KW_CACHE); } break; case 66: this.enterOuterAlt(_localctx, 66); { this.state = 1077; this.match(SparkSqlParser.KW_LOAD); this.state = 1078; this.match(SparkSqlParser.KW_DATA); this.state = 1080; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_LOCAL) { { this.state = 1079; this.match(SparkSqlParser.KW_LOCAL); } } this.state = 1082; this.match(SparkSqlParser.KW_INPATH); this.state = 1083; _localctx._path = this.stringLit(); this.state = 1085; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OVERWRITE) { { this.state = 1084; this.match(SparkSqlParser.KW_OVERWRITE); } } this.state = 1087; this.match(SparkSqlParser.KW_INTO); this.state = 1088; this.match(SparkSqlParser.KW_TABLE); this.state = 1089; this.tableName(); this.state = 1091; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 1090; this.partitionSpec(); } } } break; case 67: this.enterOuterAlt(_localctx, 67); { this.state = 1093; this.match(SparkSqlParser.KW_TRUNCATE); this.state = 1094; this.match(SparkSqlParser.KW_TABLE); this.state = 1095; this.tableName(); this.state = 1097; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 1096; this.partitionSpec(); } } } break; case 68: this.enterOuterAlt(_localctx, 68); { this.state = 1100; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_MSCK) { { this.state = 1099; this.match(SparkSqlParser.KW_MSCK); } } this.state = 1102; this.match(SparkSqlParser.KW_REPAIR); this.state = 1103; this.match(SparkSqlParser.KW_TABLE); this.state = 1104; this.tableName(); this.state = 1107; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 117, this._ctx) ) { case 1: { this.state = 1105; _localctx._option = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ADD || _la === SparkSqlParser.KW_DROP || _la === SparkSqlParser.KW_SYNC)) { _localctx._option = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 1106; this.match(SparkSqlParser.KW_PARTITIONS); } break; } } break; case 69: this.enterOuterAlt(_localctx, 69); { this.state = 1109; _localctx._op = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ADD || _la === SparkSqlParser.KW_LIST)) { _localctx._op = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 1110; this.identifier(); this.state = 1114; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 118, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 1111; this.matchWildcard(); } } } this.state = 1116; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 118, this._ctx); } } break; case 70: this.enterOuterAlt(_localctx, 70); { this.state = 1117; this.match(SparkSqlParser.KW_SET); this.state = 1118; this.match(SparkSqlParser.KW_ROLE); this.state = 1122; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 119, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 1119; this.matchWildcard(); } } } this.state = 1124; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 119, this._ctx); } } break; case 71: this.enterOuterAlt(_localctx, 71); { this.state = 1125; this.match(SparkSqlParser.KW_SET); this.state = 1126; this.match(SparkSqlParser.KW_TIME); this.state = 1127; this.match(SparkSqlParser.KW_ZONE); this.state = 1128; this.interval(); } break; case 72: this.enterOuterAlt(_localctx, 72); { this.state = 1129; this.match(SparkSqlParser.KW_SET); this.state = 1130; this.match(SparkSqlParser.KW_TIME); this.state = 1131; this.match(SparkSqlParser.KW_ZONE); this.state = 1132; this.timezone(); } break; case 73: this.enterOuterAlt(_localctx, 73); { this.state = 1133; this.match(SparkSqlParser.KW_SET); this.state = 1134; this.match(SparkSqlParser.KW_TIME); this.state = 1135; this.match(SparkSqlParser.KW_ZONE); this.state = 1139; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 120, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 1136; this.matchWildcard(); } } } this.state = 1141; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 120, this._ctx); } } break; case 74: this.enterOuterAlt(_localctx, 74); { this.state = 1142; this.match(SparkSqlParser.KW_SET); this.state = 1143; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_VAR || _la === SparkSqlParser.KW_VARIABLE)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 1144; this.assignmentList(); } break; case 75: this.enterOuterAlt(_localctx, 75); { this.state = 1145; this.match(SparkSqlParser.KW_SET); this.state = 1146; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_VAR || _la === SparkSqlParser.KW_VARIABLE)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 1147; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1148; this.multipartIdentifierList(); this.state = 1149; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 1150; this.match(SparkSqlParser.EQ); this.state = 1151; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1152; this.query(); this.state = 1153; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 76: this.enterOuterAlt(_localctx, 76); { this.state = 1155; this.match(SparkSqlParser.KW_SET); this.state = 1156; this.configKey(); this.state = 1157; this.match(SparkSqlParser.EQ); this.state = 1158; this.configValue(); } break; case 77: this.enterOuterAlt(_localctx, 77); { this.state = 1160; this.match(SparkSqlParser.KW_SET); this.state = 1161; this.configKey(); this.state = 1169; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.EQ) { { this.state = 1162; this.match(SparkSqlParser.EQ); this.state = 1166; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 121, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 1163; this.matchWildcard(); } } } this.state = 1168; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 121, this._ctx); } } } } break; case 78: this.enterOuterAlt(_localctx, 78); { this.state = 1171; this.match(SparkSqlParser.KW_SET); this.state = 1175; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 123, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 1172; this.matchWildcard(); } } } this.state = 1177; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 123, this._ctx); } this.state = 1178; this.match(SparkSqlParser.EQ); this.state = 1179; this.configValue(); } break; case 79: this.enterOuterAlt(_localctx, 79); { this.state = 1180; this.match(SparkSqlParser.KW_SET); this.state = 1184; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 124, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 1181; this.matchWildcard(); } } } this.state = 1186; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 124, this._ctx); } } break; case 80: this.enterOuterAlt(_localctx, 80); { this.state = 1187; this.match(SparkSqlParser.KW_RESET); this.state = 1188; this.configKey(); } break; case 81: this.enterOuterAlt(_localctx, 81); { this.state = 1189; this.match(SparkSqlParser.KW_RESET); this.state = 1193; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 125, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 1190; this.matchWildcard(); } } } this.state = 1195; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 125, this._ctx); } } break; case 82: this.enterOuterAlt(_localctx, 82); { this.state = 1196; this.match(SparkSqlParser.KW_CREATE); this.state = 1197; this.match(SparkSqlParser.KW_INDEX); this.state = 1199; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 126, this._ctx) ) { case 1: { this.state = 1198; this.ifNotExists(); } break; } this.state = 1201; this.identifier(); this.state = 1202; this.match(SparkSqlParser.KW_ON); this.state = 1204; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 127, this._ctx) ) { case 1: { this.state = 1203; this.match(SparkSqlParser.KW_TABLE); } break; } this.state = 1206; this.tableName(); this.state = 1209; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_USING) { { this.state = 1207; this.match(SparkSqlParser.KW_USING); this.state = 1208; _localctx._indexType = this.identifier(); } } this.state = 1211; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1212; this.multipartIdentifierPropertyList(); this.state = 1213; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 1216; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OPTIONS) { { this.state = 1214; this.match(SparkSqlParser.KW_OPTIONS); this.state = 1215; _localctx._options = this.propertyList(); } } } break; case 83: this.enterOuterAlt(_localctx, 83); { this.state = 1218; this.match(SparkSqlParser.KW_DROP); this.state = 1219; this.match(SparkSqlParser.KW_INDEX); this.state = 1221; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 130, this._ctx) ) { case 1: { this.state = 1220; this.ifExists(); } break; } this.state = 1223; this.identifier(); this.state = 1224; this.match(SparkSqlParser.KW_ON); this.state = 1226; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 131, this._ctx) ) { case 1: { this.state = 1225; this.match(SparkSqlParser.KW_TABLE); } break; } this.state = 1228; this.tableName(); } break; case 84: this.enterOuterAlt(_localctx, 84); { this.state = 1230; this.unsupportedHiveNativeCommands(); this.state = 1234; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 132, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 1231; this.matchWildcard(); } } } this.state = 1236; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 132, this._ctx); } } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public timezone(): TimezoneContext { let _localctx: TimezoneContext = new TimezoneContext(this._ctx, this.state); this.enterRule(_localctx, 6, SparkSqlParser.RULE_timezone); try { this.state = 1241; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 134, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1239; this.stringLit(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1240; this.match(SparkSqlParser.KW_LOCAL); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public configKey(): ConfigKeyContext { let _localctx: ConfigKeyContext = new ConfigKeyContext(this._ctx, this.state); this.enterRule(_localctx, 8, SparkSqlParser.RULE_configKey); try { this.enterOuterAlt(_localctx, 1); { this.state = 1243; this.quotedIdentifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public configValue(): ConfigValueContext { let _localctx: ConfigValueContext = new ConfigValueContext(this._ctx, this.state); this.enterRule(_localctx, 10, SparkSqlParser.RULE_configValue); try { this.enterOuterAlt(_localctx, 1); { this.state = 1245; this.backQuotedIdentifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unsupportedHiveNativeCommands(): UnsupportedHiveNativeCommandsContext { let _localctx: UnsupportedHiveNativeCommandsContext = new UnsupportedHiveNativeCommandsContext(this._ctx, this.state); this.enterRule(_localctx, 12, SparkSqlParser.RULE_unsupportedHiveNativeCommands); let _la: number; try { this.state = 1415; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 142, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1247; _localctx._kw1 = this.match(SparkSqlParser.KW_CREATE); this.state = 1248; _localctx._kw2 = this.match(SparkSqlParser.KW_ROLE); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1249; _localctx._kw1 = this.match(SparkSqlParser.KW_DROP); this.state = 1250; _localctx._kw2 = this.match(SparkSqlParser.KW_ROLE); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 1251; _localctx._kw1 = this.match(SparkSqlParser.KW_GRANT); this.state = 1253; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 135, this._ctx) ) { case 1: { this.state = 1252; _localctx._kw2 = this.match(SparkSqlParser.KW_ROLE); } break; } } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 1255; _localctx._kw1 = this.match(SparkSqlParser.KW_REVOKE); this.state = 1257; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 136, this._ctx) ) { case 1: { this.state = 1256; _localctx._kw2 = this.match(SparkSqlParser.KW_ROLE); } break; } } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 1259; _localctx._kw1 = this.match(SparkSqlParser.KW_SHOW); this.state = 1260; _localctx._kw2 = this.match(SparkSqlParser.KW_GRANT); } break; case 6: this.enterOuterAlt(_localctx, 6); { this.state = 1261; _localctx._kw1 = this.match(SparkSqlParser.KW_SHOW); this.state = 1262; _localctx._kw2 = this.match(SparkSqlParser.KW_ROLE); this.state = 1264; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 137, this._ctx) ) { case 1: { this.state = 1263; _localctx._kw3 = this.match(SparkSqlParser.KW_GRANT); } break; } } break; case 7: this.enterOuterAlt(_localctx, 7); { this.state = 1266; _localctx._kw1 = this.match(SparkSqlParser.KW_SHOW); this.state = 1267; _localctx._kw2 = this.match(SparkSqlParser.KW_PRINCIPALS); } break; case 8: this.enterOuterAlt(_localctx, 8); { this.state = 1268; _localctx._kw1 = this.match(SparkSqlParser.KW_SHOW); this.state = 1269; _localctx._kw2 = this.match(SparkSqlParser.KW_ROLES); } break; case 9: this.enterOuterAlt(_localctx, 9); { this.state = 1270; _localctx._kw1 = this.match(SparkSqlParser.KW_SHOW); this.state = 1271; _localctx._kw2 = this.match(SparkSqlParser.KW_CURRENT); this.state = 1272; _localctx._kw3 = this.match(SparkSqlParser.KW_ROLES); } break; case 10: this.enterOuterAlt(_localctx, 10); { this.state = 1273; _localctx._kw1 = this.match(SparkSqlParser.KW_EXPORT); this.state = 1274; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); } break; case 11: this.enterOuterAlt(_localctx, 11); { this.state = 1275; _localctx._kw1 = this.match(SparkSqlParser.KW_IMPORT); this.state = 1276; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); } break; case 12: this.enterOuterAlt(_localctx, 12); { this.state = 1277; _localctx._kw1 = this.match(SparkSqlParser.KW_SHOW); this.state = 1278; _localctx._kw2 = this.match(SparkSqlParser.KW_COMPACTIONS); } break; case 13: this.enterOuterAlt(_localctx, 13); { this.state = 1279; _localctx._kw1 = this.match(SparkSqlParser.KW_SHOW); this.state = 1280; _localctx._kw2 = this.match(SparkSqlParser.KW_CREATE); this.state = 1281; _localctx._kw3 = this.match(SparkSqlParser.KW_TABLE); } break; case 14: this.enterOuterAlt(_localctx, 14); { this.state = 1282; _localctx._kw1 = this.match(SparkSqlParser.KW_SHOW); this.state = 1283; _localctx._kw2 = this.match(SparkSqlParser.KW_TRANSACTIONS); } break; case 15: this.enterOuterAlt(_localctx, 15); { this.state = 1284; _localctx._kw1 = this.match(SparkSqlParser.KW_SHOW); this.state = 1285; _localctx._kw2 = this.match(SparkSqlParser.KW_INDEXES); } break; case 16: this.enterOuterAlt(_localctx, 16); { this.state = 1286; _localctx._kw1 = this.match(SparkSqlParser.KW_SHOW); this.state = 1287; _localctx._kw2 = this.match(SparkSqlParser.KW_LOCKS); } break; case 17: this.enterOuterAlt(_localctx, 17); { this.state = 1288; _localctx._kw1 = this.match(SparkSqlParser.KW_CREATE); this.state = 1289; _localctx._kw2 = this.match(SparkSqlParser.KW_INDEX); } break; case 18: this.enterOuterAlt(_localctx, 18); { this.state = 1290; _localctx._kw1 = this.match(SparkSqlParser.KW_DROP); this.state = 1291; _localctx._kw2 = this.match(SparkSqlParser.KW_INDEX); } break; case 19: this.enterOuterAlt(_localctx, 19); { this.state = 1292; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1293; _localctx._kw2 = this.match(SparkSqlParser.KW_INDEX); } break; case 20: this.enterOuterAlt(_localctx, 20); { this.state = 1294; _localctx._kw1 = this.match(SparkSqlParser.KW_LOCK); this.state = 1295; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); } break; case 21: this.enterOuterAlt(_localctx, 21); { this.state = 1296; _localctx._kw1 = this.match(SparkSqlParser.KW_LOCK); this.state = 1297; _localctx._kw2 = this.match(SparkSqlParser.KW_DATABASE); } break; case 22: this.enterOuterAlt(_localctx, 22); { this.state = 1298; _localctx._kw1 = this.match(SparkSqlParser.KW_UNLOCK); this.state = 1299; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); } break; case 23: this.enterOuterAlt(_localctx, 23); { this.state = 1300; _localctx._kw1 = this.match(SparkSqlParser.KW_UNLOCK); this.state = 1301; _localctx._kw2 = this.match(SparkSqlParser.KW_DATABASE); } break; case 24: this.enterOuterAlt(_localctx, 24); { this.state = 1302; _localctx._kw1 = this.match(SparkSqlParser.KW_CREATE); this.state = 1303; _localctx._kw2 = this.match(SparkSqlParser.KW_TEMPORARY); this.state = 1304; _localctx._kw3 = this.match(SparkSqlParser.KW_MACRO); } break; case 25: this.enterOuterAlt(_localctx, 25); { this.state = 1305; _localctx._kw1 = this.match(SparkSqlParser.KW_DROP); this.state = 1306; _localctx._kw2 = this.match(SparkSqlParser.KW_TEMPORARY); this.state = 1307; _localctx._kw3 = this.match(SparkSqlParser.KW_MACRO); } break; case 26: this.enterOuterAlt(_localctx, 26); { this.state = 1308; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1309; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1310; this.tableName(); this.state = 1311; _localctx._kw3 = this.match(SparkSqlParser.KW_NOT); this.state = 1312; _localctx._kw4 = this.match(SparkSqlParser.KW_CLUSTERED); } break; case 27: this.enterOuterAlt(_localctx, 27); { this.state = 1314; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1315; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1316; this.tableName(); this.state = 1317; _localctx._kw3 = this.match(SparkSqlParser.KW_CLUSTERED); this.state = 1318; _localctx._kw4 = this.match(SparkSqlParser.KW_BY); } break; case 28: this.enterOuterAlt(_localctx, 28); { this.state = 1320; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1321; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1322; this.tableName(); this.state = 1323; _localctx._kw3 = this.match(SparkSqlParser.KW_NOT); this.state = 1324; _localctx._kw4 = this.match(SparkSqlParser.KW_SORTED); } break; case 29: this.enterOuterAlt(_localctx, 29); { this.state = 1326; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1327; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1328; this.tableName(); this.state = 1329; _localctx._kw3 = this.match(SparkSqlParser.KW_SKEWED); this.state = 1330; _localctx._kw4 = this.match(SparkSqlParser.KW_BY); } break; case 30: this.enterOuterAlt(_localctx, 30); { this.state = 1332; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1333; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1334; this.tableName(); this.state = 1335; _localctx._kw3 = this.match(SparkSqlParser.KW_NOT); this.state = 1336; _localctx._kw4 = this.match(SparkSqlParser.KW_SKEWED); } break; case 31: this.enterOuterAlt(_localctx, 31); { this.state = 1338; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1339; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1340; this.tableName(); this.state = 1341; _localctx._kw3 = this.match(SparkSqlParser.KW_NOT); this.state = 1342; _localctx._kw4 = this.match(SparkSqlParser.KW_STORED); this.state = 1343; _localctx._kw5 = this.match(SparkSqlParser.KW_AS); this.state = 1344; _localctx._kw6 = this.match(SparkSqlParser.KW_DIRECTORIES); } break; case 32: this.enterOuterAlt(_localctx, 32); { this.state = 1346; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1347; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1348; this.tableName(); this.state = 1349; _localctx._kw3 = this.match(SparkSqlParser.KW_SET); this.state = 1350; _localctx._kw4 = this.match(SparkSqlParser.KW_SKEWED); this.state = 1351; _localctx._kw5 = this.match(SparkSqlParser.KW_LOCATION); } break; case 33: this.enterOuterAlt(_localctx, 33); { this.state = 1353; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1354; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1355; this.tableName(); this.state = 1356; _localctx._kw3 = this.match(SparkSqlParser.KW_EXCHANGE); this.state = 1357; _localctx._kw4 = this.match(SparkSqlParser.KW_PARTITION); } break; case 34: this.enterOuterAlt(_localctx, 34); { this.state = 1359; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1360; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1361; this.tableName(); this.state = 1362; _localctx._kw3 = this.match(SparkSqlParser.KW_ARCHIVE); this.state = 1363; _localctx._kw4 = this.match(SparkSqlParser.KW_PARTITION); } break; case 35: this.enterOuterAlt(_localctx, 35); { this.state = 1365; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1366; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1367; this.tableName(); this.state = 1368; _localctx._kw3 = this.match(SparkSqlParser.KW_UNARCHIVE); this.state = 1369; _localctx._kw4 = this.match(SparkSqlParser.KW_PARTITION); } break; case 36: this.enterOuterAlt(_localctx, 36); { this.state = 1371; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1372; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1373; this.tableName(); this.state = 1374; _localctx._kw3 = this.match(SparkSqlParser.KW_TOUCH); } break; case 37: this.enterOuterAlt(_localctx, 37); { this.state = 1376; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1377; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1378; this.tableName(); this.state = 1380; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 1379; this.partitionSpec(); } } this.state = 1382; _localctx._kw3 = this.match(SparkSqlParser.KW_COMPACT); } break; case 38: this.enterOuterAlt(_localctx, 38); { this.state = 1384; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1385; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1386; this.tableName(); this.state = 1388; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 1387; this.partitionSpec(); } } this.state = 1390; _localctx._kw3 = this.match(SparkSqlParser.KW_CONCATENATE); } break; case 39: this.enterOuterAlt(_localctx, 39); { this.state = 1392; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1393; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1394; this.tableName(); this.state = 1396; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 1395; this.partitionSpec(); } } this.state = 1398; _localctx._kw3 = this.match(SparkSqlParser.KW_SET); this.state = 1399; _localctx._kw4 = this.match(SparkSqlParser.KW_FILEFORMAT); } break; case 40: this.enterOuterAlt(_localctx, 40); { this.state = 1401; _localctx._kw1 = this.match(SparkSqlParser.KW_ALTER); this.state = 1402; _localctx._kw2 = this.match(SparkSqlParser.KW_TABLE); this.state = 1403; this.tableName(); this.state = 1405; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 1404; this.partitionSpec(); } } this.state = 1407; _localctx._kw3 = this.match(SparkSqlParser.KW_REPLACE); this.state = 1408; _localctx._kw4 = this.match(SparkSqlParser.KW_COLUMNS); } break; case 41: this.enterOuterAlt(_localctx, 41); { this.state = 1410; _localctx._kw1 = this.match(SparkSqlParser.KW_START); this.state = 1411; _localctx._kw2 = this.match(SparkSqlParser.KW_TRANSACTION); } break; case 42: this.enterOuterAlt(_localctx, 42); { this.state = 1412; _localctx._kw1 = this.match(SparkSqlParser.KW_COMMIT); } break; case 43: this.enterOuterAlt(_localctx, 43); { this.state = 1413; _localctx._kw1 = this.match(SparkSqlParser.KW_ROLLBACK); } break; case 44: this.enterOuterAlt(_localctx, 44); { this.state = 1414; _localctx._kw1 = this.match(SparkSqlParser.KW_DFS); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public createTableHeader(): CreateTableHeaderContext { let _localctx: CreateTableHeaderContext = new CreateTableHeaderContext(this._ctx, this.state); this.enterRule(_localctx, 14, SparkSqlParser.RULE_createTableHeader); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1417; this.match(SparkSqlParser.KW_CREATE); this.state = 1419; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_TEMPORARY) { { this.state = 1418; this.match(SparkSqlParser.KW_TEMPORARY); } } this.state = 1422; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_EXTERNAL) { { this.state = 1421; this.match(SparkSqlParser.KW_EXTERNAL); } } this.state = 1424; this.match(SparkSqlParser.KW_TABLE); this.state = 1426; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 145, this._ctx) ) { case 1: { this.state = 1425; this.ifNotExists(); } break; } this.state = 1428; this.tableNameCreate(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public replaceTableHeader(): ReplaceTableHeaderContext { let _localctx: ReplaceTableHeaderContext = new ReplaceTableHeaderContext(this._ctx, this.state); this.enterRule(_localctx, 16, SparkSqlParser.RULE_replaceTableHeader); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1432; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_CREATE) { { this.state = 1430; this.match(SparkSqlParser.KW_CREATE); this.state = 1431; this.match(SparkSqlParser.KW_OR); } } this.state = 1434; this.match(SparkSqlParser.KW_REPLACE); this.state = 1435; this.match(SparkSqlParser.KW_TABLE); this.state = 1436; this.tableNameCreate(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public bucketSpec(): BucketSpecContext { let _localctx: BucketSpecContext = new BucketSpecContext(this._ctx, this.state); this.enterRule(_localctx, 18, SparkSqlParser.RULE_bucketSpec); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1438; this.match(SparkSqlParser.KW_CLUSTERED); this.state = 1439; this.match(SparkSqlParser.KW_BY); this.state = 1440; this.identifierList(); this.state = 1444; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_SORTED) { { this.state = 1441; this.match(SparkSqlParser.KW_SORTED); this.state = 1442; this.match(SparkSqlParser.KW_BY); this.state = 1443; this.orderedIdentifierList(); } } this.state = 1446; this.match(SparkSqlParser.KW_INTO); this.state = 1447; this.match(SparkSqlParser.INTEGER_VALUE); this.state = 1448; this.match(SparkSqlParser.KW_BUCKETS); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public skewSpec(): SkewSpecContext { let _localctx: SkewSpecContext = new SkewSpecContext(this._ctx, this.state); this.enterRule(_localctx, 20, SparkSqlParser.RULE_skewSpec); try { this.enterOuterAlt(_localctx, 1); { this.state = 1450; this.match(SparkSqlParser.KW_SKEWED); this.state = 1451; this.match(SparkSqlParser.KW_BY); this.state = 1452; this.identifierList(); this.state = 1453; this.match(SparkSqlParser.KW_ON); this.state = 1456; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 148, this._ctx) ) { case 1: { this.state = 1454; this.constantList(); } break; case 2: { this.state = 1455; this.nestedConstantList(); } break; } this.state = 1461; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 149, this._ctx) ) { case 1: { this.state = 1458; this.match(SparkSqlParser.KW_STORED); this.state = 1459; this.match(SparkSqlParser.KW_AS); this.state = 1460; this.match(SparkSqlParser.KW_DIRECTORIES); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public locationSpec(): LocationSpecContext { let _localctx: LocationSpecContext = new LocationSpecContext(this._ctx, this.state); this.enterRule(_localctx, 22, SparkSqlParser.RULE_locationSpec); try { this.enterOuterAlt(_localctx, 1); { this.state = 1463; this.match(SparkSqlParser.KW_LOCATION); this.state = 1464; this.stringLit(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public commentSpec(): CommentSpecContext { let _localctx: CommentSpecContext = new CommentSpecContext(this._ctx, this.state); this.enterRule(_localctx, 24, SparkSqlParser.RULE_commentSpec); try { this.enterOuterAlt(_localctx, 1); { this.state = 1466; this.match(SparkSqlParser.KW_COMMENT); this.state = 1467; this.stringLit(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public query(): QueryContext { let _localctx: QueryContext = new QueryContext(this._ctx, this.state); this.enterRule(_localctx, 26, SparkSqlParser.RULE_query); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1470; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_WITH) { { this.state = 1469; this.ctes(); } } this.state = 1472; this.queryTerm(0); this.state = 1473; this.queryOrganization(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public insertInto(): InsertIntoContext { let _localctx: InsertIntoContext = new InsertIntoContext(this._ctx, this.state); this.enterRule(_localctx, 28, SparkSqlParser.RULE_insertInto); let _la: number; try { this.state = 1545; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 166, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1475; this.match(SparkSqlParser.KW_INSERT); this.state = 1476; this.match(SparkSqlParser.KW_OVERWRITE); this.state = 1478; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 151, this._ctx) ) { case 1: { this.state = 1477; this.match(SparkSqlParser.KW_TABLE); } break; } this.state = 1480; this.tableName(); this.state = 1485; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 1481; this.partitionSpec(); this.state = 1483; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_IF) { { this.state = 1482; this.ifNotExists(); } } } } this.state = 1490; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 154, this._ctx) ) { case 1: { { this.state = 1487; this.match(SparkSqlParser.KW_BY); this.state = 1488; this.match(SparkSqlParser.KW_NAME); } } break; case 2: { this.state = 1489; this.identifierList(); } break; } } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1492; this.match(SparkSqlParser.KW_INSERT); this.state = 1493; this.match(SparkSqlParser.KW_INTO); this.state = 1495; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 155, this._ctx) ) { case 1: { this.state = 1494; this.match(SparkSqlParser.KW_TABLE); } break; } this.state = 1497; this.tableName(); this.state = 1499; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_PARTITION) { { this.state = 1498; this.partitionSpec(); } } this.state = 1502; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_IF) { { this.state = 1501; this.ifNotExists(); } } this.state = 1507; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 158, this._ctx) ) { case 1: { { this.state = 1504; this.match(SparkSqlParser.KW_BY); this.state = 1505; this.match(SparkSqlParser.KW_NAME); } } break; case 2: { this.state = 1506; this.identifierList(); } break; } } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 1509; this.match(SparkSqlParser.KW_INSERT); this.state = 1510; this.match(SparkSqlParser.KW_INTO); this.state = 1512; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 159, this._ctx) ) { case 1: { this.state = 1511; this.match(SparkSqlParser.KW_TABLE); } break; } this.state = 1514; this.tableName(); this.state = 1515; this.match(SparkSqlParser.KW_REPLACE); this.state = 1516; this.whereClause(); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 1518; this.match(SparkSqlParser.KW_INSERT); this.state = 1519; this.match(SparkSqlParser.KW_OVERWRITE); this.state = 1521; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_LOCAL) { { this.state = 1520; this.match(SparkSqlParser.KW_LOCAL); } } this.state = 1523; this.match(SparkSqlParser.KW_DIRECTORY); this.state = 1524; _localctx._path = this.stringLit(); this.state = 1526; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ROW) { { this.state = 1525; this.rowFormat(); } } this.state = 1529; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_STORED) { { this.state = 1528; this.createFileFormat(); } } } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 1531; this.match(SparkSqlParser.KW_INSERT); this.state = 1532; this.match(SparkSqlParser.KW_OVERWRITE); this.state = 1534; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_LOCAL) { { this.state = 1533; this.match(SparkSqlParser.KW_LOCAL); } } this.state = 1536; this.match(SparkSqlParser.KW_DIRECTORY); this.state = 1538; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 164, this._ctx) ) { case 1: { this.state = 1537; _localctx._path = this.stringLit(); } break; } this.state = 1540; this.tableProvider(); this.state = 1543; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OPTIONS) { { this.state = 1541; this.match(SparkSqlParser.KW_OPTIONS); this.state = 1542; _localctx._options = this.propertyList(); } } } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public partitionSpecLocation(): PartitionSpecLocationContext { let _localctx: PartitionSpecLocationContext = new PartitionSpecLocationContext(this._ctx, this.state); this.enterRule(_localctx, 30, SparkSqlParser.RULE_partitionSpecLocation); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1547; this.partitionSpec(); this.state = 1549; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_LOCATION) { { this.state = 1548; this.locationSpec(); } } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public partitionSpec(): PartitionSpecContext { let _localctx: PartitionSpecContext = new PartitionSpecContext(this._ctx, this.state); this.enterRule(_localctx, 32, SparkSqlParser.RULE_partitionSpec); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1551; this.match(SparkSqlParser.KW_PARTITION); this.state = 1552; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1553; this.partitionVal(); this.state = 1558; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 1554; this.match(SparkSqlParser.COMMA); this.state = 1555; this.partitionVal(); } } this.state = 1560; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 1561; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public partitionVal(): PartitionValContext { let _localctx: PartitionValContext = new PartitionValContext(this._ctx, this.state); this.enterRule(_localctx, 34, SparkSqlParser.RULE_partitionVal); let _la: number; try { this.state = 1572; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 170, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1563; this.identifier(); this.state = 1566; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.EQ) { { this.state = 1564; this.match(SparkSqlParser.EQ); this.state = 1565; this.constant(); } } } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1568; this.identifier(); this.state = 1569; this.match(SparkSqlParser.EQ); this.state = 1570; this.match(SparkSqlParser.KW_DEFAULT); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public dbSchema(): DbSchemaContext { let _localctx: DbSchemaContext = new DbSchemaContext(this._ctx, this.state); this.enterRule(_localctx, 36, SparkSqlParser.RULE_dbSchema); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1574; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DATABASE || _la === SparkSqlParser.KW_NAMESPACE || _la === SparkSqlParser.KW_SCHEMA)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public dbSchemas(): DbSchemasContext { let _localctx: DbSchemasContext = new DbSchemasContext(this._ctx, this.state); this.enterRule(_localctx, 38, SparkSqlParser.RULE_dbSchemas); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1576; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DATABASES || _la === SparkSqlParser.KW_NAMESPACES || _la === SparkSqlParser.KW_SCHEMAS)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public describeFuncName(): DescribeFuncNameContext { let _localctx: DescribeFuncNameContext = new DescribeFuncNameContext(this._ctx, this.state); this.enterRule(_localctx, 40, SparkSqlParser.RULE_describeFuncName); try { this.state = 1583; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 171, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1578; this.identifierReference(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1579; this.stringLit(); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 1580; this.comparisonOperator(); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 1581; this.arithmeticOperator(); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 1582; this.predicateOperator(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public describeColName(): DescribeColNameContext { let _localctx: DescribeColNameContext = new DescribeColNameContext(this._ctx, this.state); this.enterRule(_localctx, 42, SparkSqlParser.RULE_describeColName); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1585; _localctx._identifier = this.identifier(); _localctx._nameParts.push(_localctx._identifier); this.state = 1590; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.DOT) { { { this.state = 1586; this.match(SparkSqlParser.DOT); this.state = 1587; _localctx._identifier = this.identifier(); _localctx._nameParts.push(_localctx._identifier); } } this.state = 1592; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public ctes(): CtesContext { let _localctx: CtesContext = new CtesContext(this._ctx, this.state); this.enterRule(_localctx, 44, SparkSqlParser.RULE_ctes); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1593; this.match(SparkSqlParser.KW_WITH); this.state = 1594; this.namedQuery(); this.state = 1599; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 1595; this.match(SparkSqlParser.COMMA); this.state = 1596; this.namedQuery(); } } this.state = 1601; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public namedQuery(): NamedQueryContext { let _localctx: NamedQueryContext = new NamedQueryContext(this._ctx, this.state); this.enterRule(_localctx, 46, SparkSqlParser.RULE_namedQuery); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1602; _localctx._name = this.errorCapturingIdentifier(); this.state = 1604; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 174, this._ctx) ) { case 1: { this.state = 1603; _localctx._columnAliases = this.identifierList(); } break; } this.state = 1607; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_AS) { { this.state = 1606; this.match(SparkSqlParser.KW_AS); } } this.state = 1609; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1610; this.query(); this.state = 1611; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public tableProvider(): TableProviderContext { let _localctx: TableProviderContext = new TableProviderContext(this._ctx, this.state); this.enterRule(_localctx, 48, SparkSqlParser.RULE_tableProvider); try { this.enterOuterAlt(_localctx, 1); { this.state = 1613; this.match(SparkSqlParser.KW_USING); this.state = 1614; this.multipartIdentifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public createTableClauses(): CreateTableClausesContext { let _localctx: CreateTableClausesContext = new CreateTableClausesContext(this._ctx, this.state); this.enterRule(_localctx, 50, SparkSqlParser.RULE_createTableClauses); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 1631; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 177, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { this.state = 1629; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_OPTIONS: { { this.state = 1616; this.match(SparkSqlParser.KW_OPTIONS); this.state = 1617; _localctx._options = this.expressionPropertyList(); } } break; case SparkSqlParser.KW_PARTITIONED: { { this.state = 1618; this.match(SparkSqlParser.KW_PARTITIONED); this.state = 1619; this.match(SparkSqlParser.KW_BY); this.state = 1620; _localctx._partitioning = this.partitionFieldList(); } } break; case SparkSqlParser.KW_SKEWED: { this.state = 1621; this.skewSpec(); } break; case SparkSqlParser.KW_CLUSTERED: { this.state = 1622; this.bucketSpec(); } break; case SparkSqlParser.KW_ROW: { this.state = 1623; this.rowFormat(); } break; case SparkSqlParser.KW_STORED: { this.state = 1624; this.createFileFormat(); } break; case SparkSqlParser.KW_LOCATION: { this.state = 1625; this.locationSpec(); } break; case SparkSqlParser.KW_COMMENT: { this.state = 1626; this.commentSpec(); } break; case SparkSqlParser.KW_TBLPROPERTIES: { { this.state = 1627; this.match(SparkSqlParser.KW_TBLPROPERTIES); this.state = 1628; _localctx._tableProps = this.propertyList(); } } break; default: throw new NoViableAltException(this); } } } this.state = 1633; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 177, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public propertyList(): PropertyListContext { let _localctx: PropertyListContext = new PropertyListContext(this._ctx, this.state); this.enterRule(_localctx, 52, SparkSqlParser.RULE_propertyList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1634; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1635; this.property(); this.state = 1640; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 1636; this.match(SparkSqlParser.COMMA); this.state = 1637; this.property(); } } this.state = 1642; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 1643; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public property(): PropertyContext { let _localctx: PropertyContext = new PropertyContext(this._ctx, this.state); this.enterRule(_localctx, 54, SparkSqlParser.RULE_property); try { this.enterOuterAlt(_localctx, 1); { this.state = 1645; _localctx._key = this.propertyKey(); this.state = 1650; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 180, this._ctx) ) { case 1: { this.state = 1647; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 179, this._ctx) ) { case 1: { this.state = 1646; this.match(SparkSqlParser.EQ); } break; } this.state = 1649; _localctx._value = this.propertyValue(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public propertyKey(): PropertyKeyContext { let _localctx: PropertyKeyContext = new PropertyKeyContext(this._ctx, this.state); this.enterRule(_localctx, 56, SparkSqlParser.RULE_propertyKey); try { let _alt: number; this.state = 1661; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 182, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1652; this.identifier(); this.state = 1657; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 181, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 1653; this.match(SparkSqlParser.DOT); this.state = 1654; this.identifier(); } } } this.state = 1659; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 181, this._ctx); } } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1660; this.stringLit(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public propertyValue(): PropertyValueContext { let _localctx: PropertyValueContext = new PropertyValueContext(this._ctx, this.state); this.enterRule(_localctx, 58, SparkSqlParser.RULE_propertyValue); try { this.state = 1667; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 183, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1663; this.match(SparkSqlParser.INTEGER_VALUE); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1664; this.match(SparkSqlParser.DECIMAL_VALUE); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 1665; this.booleanValue(); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 1666; this.stringLit(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public expressionPropertyList(): ExpressionPropertyListContext { let _localctx: ExpressionPropertyListContext = new ExpressionPropertyListContext(this._ctx, this.state); this.enterRule(_localctx, 60, SparkSqlParser.RULE_expressionPropertyList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1669; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1670; this.expressionProperty(); this.state = 1675; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 1671; this.match(SparkSqlParser.COMMA); this.state = 1672; this.expressionProperty(); } } this.state = 1677; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 1678; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public expressionProperty(): ExpressionPropertyContext { let _localctx: ExpressionPropertyContext = new ExpressionPropertyContext(this._ctx, this.state); this.enterRule(_localctx, 62, SparkSqlParser.RULE_expressionProperty); try { this.enterOuterAlt(_localctx, 1); { this.state = 1680; _localctx._key = this.propertyKey(); this.state = 1685; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 186, this._ctx) ) { case 1: { this.state = 1682; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 185, this._ctx) ) { case 1: { this.state = 1681; this.match(SparkSqlParser.EQ); } break; } this.state = 1684; _localctx._value = this.expression(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public constantList(): ConstantListContext { let _localctx: ConstantListContext = new ConstantListContext(this._ctx, this.state); this.enterRule(_localctx, 64, SparkSqlParser.RULE_constantList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1687; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1688; this.constant(); this.state = 1693; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 1689; this.match(SparkSqlParser.COMMA); this.state = 1690; this.constant(); } } this.state = 1695; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 1696; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public nestedConstantList(): NestedConstantListContext { let _localctx: NestedConstantListContext = new NestedConstantListContext(this._ctx, this.state); this.enterRule(_localctx, 66, SparkSqlParser.RULE_nestedConstantList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1698; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1699; this.constantList(); this.state = 1704; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 1700; this.match(SparkSqlParser.COMMA); this.state = 1701; this.constantList(); } } this.state = 1706; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 1707; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public createFileFormat(): CreateFileFormatContext { let _localctx: CreateFileFormatContext = new CreateFileFormatContext(this._ctx, this.state); this.enterRule(_localctx, 68, SparkSqlParser.RULE_createFileFormat); try { this.state = 1715; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 189, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1709; this.match(SparkSqlParser.KW_STORED); this.state = 1710; this.match(SparkSqlParser.KW_AS); this.state = 1711; this.fileFormat(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1712; this.match(SparkSqlParser.KW_STORED); this.state = 1713; this.match(SparkSqlParser.KW_BY); this.state = 1714; this.storageHandler(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public fileFormat(): FileFormatContext { let _localctx: FileFormatContext = new FileFormatContext(this._ctx, this.state); this.enterRule(_localctx, 70, SparkSqlParser.RULE_fileFormat); try { this.state = 1723; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 190, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1717; this.match(SparkSqlParser.KW_INPUTFORMAT); this.state = 1718; _localctx._inFmt = this.stringLit(); this.state = 1719; this.match(SparkSqlParser.KW_OUTPUTFORMAT); this.state = 1720; _localctx._outFmt = this.stringLit(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1722; this.identifier(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public storageHandler(): StorageHandlerContext { let _localctx: StorageHandlerContext = new StorageHandlerContext(this._ctx, this.state); this.enterRule(_localctx, 72, SparkSqlParser.RULE_storageHandler); try { this.enterOuterAlt(_localctx, 1); { this.state = 1725; this.stringLit(); this.state = 1729; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 191, this._ctx) ) { case 1: { this.state = 1726; this.match(SparkSqlParser.KW_WITH); this.state = 1727; this.match(SparkSqlParser.KW_SERDEPROPERTIES); this.state = 1728; this.propertyList(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public resource(): ResourceContext { let _localctx: ResourceContext = new ResourceContext(this._ctx, this.state); this.enterRule(_localctx, 74, SparkSqlParser.RULE_resource); try { this.enterOuterAlt(_localctx, 1); { this.state = 1731; this.identifier(); this.state = 1732; this.stringLit(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public dmlStatementNoWith(): DmlStatementNoWithContext { let _localctx: DmlStatementNoWithContext = new DmlStatementNoWithContext(this._ctx, this.state); this.enterRule(_localctx, 76, SparkSqlParser.RULE_dmlStatementNoWith); let _la: number; try { let _alt: number; this.state = 1790; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_INSERT: this.enterOuterAlt(_localctx, 1); { this.state = 1734; this.insertInto(); this.state = 1735; this.query(); } break; case SparkSqlParser.KW_FROM: this.enterOuterAlt(_localctx, 2); { this.state = 1737; this.fromClause(); this.state = 1739; this._errHandler.sync(this); _alt = 1; do { switch (_alt) { case 1: { { this.state = 1738; this.multiInsertQueryBody(); } } break; default: throw new NoViableAltException(this); } this.state = 1741; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 192, this._ctx); } while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER); } break; case SparkSqlParser.KW_DELETE: this.enterOuterAlt(_localctx, 3); { this.state = 1743; this.match(SparkSqlParser.KW_DELETE); this.state = 1744; this.match(SparkSqlParser.KW_FROM); this.state = 1745; this.tableName(); this.state = 1746; this.tableAlias(); this.state = 1748; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_WHERE) { { this.state = 1747; this.whereClause(); } } } break; case SparkSqlParser.KW_UPDATE: this.enterOuterAlt(_localctx, 4); { this.state = 1750; this.match(SparkSqlParser.KW_UPDATE); this.state = 1751; this.tableName(); this.state = 1752; this.tableAlias(); this.state = 1753; this.setClause(); this.state = 1755; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_WHERE) { { this.state = 1754; this.whereClause(); } } } break; case SparkSqlParser.KW_MERGE: this.enterOuterAlt(_localctx, 5); { this.state = 1757; this.match(SparkSqlParser.KW_MERGE); this.state = 1758; this.match(SparkSqlParser.KW_INTO); this.state = 1759; _localctx._target = this.tableName(); this.state = 1760; _localctx._targetAlias = this.tableAlias(); this.state = 1761; this.match(SparkSqlParser.KW_USING); this.state = 1767; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 195, this._ctx) ) { case 1: { this.state = 1762; _localctx._source = this.identifierReference(); } break; case 2: { this.state = 1763; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1764; _localctx._sourceQuery = this.query(); this.state = 1765; this.match(SparkSqlParser.RIGHT_PAREN); } break; } this.state = 1769; _localctx._sourceAlias = this.tableAlias(); this.state = 1770; this.match(SparkSqlParser.KW_ON); this.state = 1771; _localctx._mergeCondition = this.booleanExpression(0); this.state = 1775; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 196, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 1772; this.matchedClause(); } } } this.state = 1777; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 196, this._ctx); } this.state = 1781; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 197, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 1778; this.notMatchedClause(); } } } this.state = 1783; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 197, this._ctx); } this.state = 1787; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.KW_WHEN) { { { this.state = 1784; this.notMatchedBySourceClause(); } } this.state = 1789; this._errHandler.sync(this); _la = this._input.LA(1); } } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public dbSchemaName(): DbSchemaNameContext { let _localctx: DbSchemaNameContext = new DbSchemaNameContext(this._ctx, this.state); this.enterRule(_localctx, 78, SparkSqlParser.RULE_dbSchemaName); try { this.enterOuterAlt(_localctx, 1); { this.state = 1792; this.identifierReference(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public dbSchemaNameCreate(): DbSchemaNameCreateContext { let _localctx: DbSchemaNameCreateContext = new DbSchemaNameCreateContext(this._ctx, this.state); this.enterRule(_localctx, 80, SparkSqlParser.RULE_dbSchemaNameCreate); try { this.enterOuterAlt(_localctx, 1); { this.state = 1794; this.identifierReference(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public tableNameCreate(): TableNameCreateContext { let _localctx: TableNameCreateContext = new TableNameCreateContext(this._ctx, this.state); this.enterRule(_localctx, 82, SparkSqlParser.RULE_tableNameCreate); try { this.enterOuterAlt(_localctx, 1); { this.state = 1796; this.tableIdentifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public tableName(): TableNameContext { let _localctx: TableNameContext = new TableNameContext(this._ctx, this.state); this.enterRule(_localctx, 84, SparkSqlParser.RULE_tableName); try { this.enterOuterAlt(_localctx, 1); { this.state = 1798; this.tableIdentifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public viewNameCreate(): ViewNameCreateContext { let _localctx: ViewNameCreateContext = new ViewNameCreateContext(this._ctx, this.state); this.enterRule(_localctx, 86, SparkSqlParser.RULE_viewNameCreate); try { this.enterOuterAlt(_localctx, 1); { this.state = 1800; this.viewIdentifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public viewName(): ViewNameContext { let _localctx: ViewNameContext = new ViewNameContext(this._ctx, this.state); this.enterRule(_localctx, 88, SparkSqlParser.RULE_viewName); try { this.enterOuterAlt(_localctx, 1); { this.state = 1802; this.viewIdentifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public identifierReference(): IdentifierReferenceContext { let _localctx: IdentifierReferenceContext = new IdentifierReferenceContext(this._ctx, this.state); this.enterRule(_localctx, 90, SparkSqlParser.RULE_identifierReference); try { this.state = 1810; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 200, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1804; this.match(SparkSqlParser.KW_IDENTIFIER_KW); this.state = 1805; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1806; this.expression(); this.state = 1807; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1809; this.multipartIdentifier(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public queryOrganization(): QueryOrganizationContext { let _localctx: QueryOrganizationContext = new QueryOrganizationContext(this._ctx, this.state); this.enterRule(_localctx, 92, SparkSqlParser.RULE_queryOrganization); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 1822; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 202, this._ctx) ) { case 1: { this.state = 1812; this.match(SparkSqlParser.KW_ORDER); this.state = 1813; this.match(SparkSqlParser.KW_BY); this.state = 1814; _localctx._sortItem = this.sortItem(); _localctx._order.push(_localctx._sortItem); this.state = 1819; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 201, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 1815; this.match(SparkSqlParser.COMMA); this.state = 1816; _localctx._sortItem = this.sortItem(); _localctx._order.push(_localctx._sortItem); } } } this.state = 1821; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 201, this._ctx); } } break; } this.state = 1834; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 204, this._ctx) ) { case 1: { this.state = 1824; this.match(SparkSqlParser.KW_CLUSTER); this.state = 1825; this.match(SparkSqlParser.KW_BY); this.state = 1826; _localctx._expression = this.expression(); _localctx._clusterBy.push(_localctx._expression); this.state = 1831; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 203, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 1827; this.match(SparkSqlParser.COMMA); this.state = 1828; _localctx._expression = this.expression(); _localctx._clusterBy.push(_localctx._expression); } } } this.state = 1833; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 203, this._ctx); } } break; } this.state = 1846; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 206, this._ctx) ) { case 1: { this.state = 1836; this.match(SparkSqlParser.KW_DISTRIBUTE); this.state = 1837; this.match(SparkSqlParser.KW_BY); this.state = 1838; _localctx._expression = this.expression(); _localctx._distributeBy.push(_localctx._expression); this.state = 1843; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 205, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 1839; this.match(SparkSqlParser.COMMA); this.state = 1840; _localctx._expression = this.expression(); _localctx._distributeBy.push(_localctx._expression); } } } this.state = 1845; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 205, this._ctx); } } break; } this.state = 1858; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 208, this._ctx) ) { case 1: { this.state = 1848; this.match(SparkSqlParser.KW_SORT); this.state = 1849; this.match(SparkSqlParser.KW_BY); this.state = 1850; _localctx._sortItem = this.sortItem(); _localctx._sort.push(_localctx._sortItem); this.state = 1855; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 207, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 1851; this.match(SparkSqlParser.COMMA); this.state = 1852; _localctx._sortItem = this.sortItem(); _localctx._sort.push(_localctx._sortItem); } } } this.state = 1857; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 207, this._ctx); } } break; } this.state = 1861; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 209, this._ctx) ) { case 1: { this.state = 1860; this.windowClause(); } break; } this.state = 1868; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 211, this._ctx) ) { case 1: { this.state = 1863; this.match(SparkSqlParser.KW_LIMIT); this.state = 1866; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 210, this._ctx) ) { case 1: { this.state = 1864; this.match(SparkSqlParser.KW_ALL); } break; case 2: { this.state = 1865; _localctx._limit = this.expression(); } break; } } break; } this.state = 1872; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 212, this._ctx) ) { case 1: { this.state = 1870; this.match(SparkSqlParser.KW_OFFSET); this.state = 1871; _localctx._offset = this.expression(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public multiInsertQueryBody(): MultiInsertQueryBodyContext { let _localctx: MultiInsertQueryBodyContext = new MultiInsertQueryBodyContext(this._ctx, this.state); this.enterRule(_localctx, 94, SparkSqlParser.RULE_multiInsertQueryBody); try { this.enterOuterAlt(_localctx, 1); { this.state = 1874; this.insertInto(); this.state = 1875; this.fromStatementBody(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } public queryTerm(): QueryTermContext; public queryTerm(_p: number): QueryTermContext; // @RuleVersion(0) public queryTerm(_p?: number): QueryTermContext { if (_p === undefined) { _p = 0; } let _parentctx: ParserRuleContext = this._ctx; let _parentState: number = this.state; let _localctx: QueryTermContext = new QueryTermContext(this._ctx, _parentState); let _prevctx: QueryTermContext = _localctx; let _startState: number = 96; this.enterRecursionRule(_localctx, 96, SparkSqlParser.RULE_queryTerm, _p); let _la: number; try { let _alt: number; this.enterOuterAlt(_localctx, 1); { { this.state = 1878; this.queryPrimary(); } this._ctx._stop = this._input.tryLT(-1); this.state = 1903; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 217, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { if (this._parseListeners != null) { this.triggerExitRuleEvent(); } _prevctx = _localctx; { this.state = 1901; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 216, this._ctx) ) { case 1: { _localctx = new QueryTermContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_queryTerm); this.state = 1880; if (!(this.precpred(this._ctx, 3))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 3)"); } this.state = 1881; if (!(this.legacy_setops_precedence_enabled)) { throw this.createFailedPredicateException("this.legacy_setops_precedence_enabled"); } this.state = 1882; _localctx._operator = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_EXCEPT || _la === SparkSqlParser.KW_INTERSECT || _la === SparkSqlParser.KW_SETMINUS || _la === SparkSqlParser.KW_UNION)) { _localctx._operator = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 1884; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ALL || _la === SparkSqlParser.KW_DISTINCT) { { this.state = 1883; this.setQuantifier(); } } this.state = 1886; _localctx._right = this.queryTerm(4); } break; case 2: { _localctx = new QueryTermContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_queryTerm); this.state = 1887; if (!(this.precpred(this._ctx, 2))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 2)"); } this.state = 1888; if (!(!this.legacy_setops_precedence_enabled)) { throw this.createFailedPredicateException("!this.legacy_setops_precedence_enabled"); } this.state = 1889; _localctx._operator = this.match(SparkSqlParser.KW_INTERSECT); this.state = 1891; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ALL || _la === SparkSqlParser.KW_DISTINCT) { { this.state = 1890; this.setQuantifier(); } } this.state = 1893; _localctx._right = this.queryTerm(3); } break; case 3: { _localctx = new QueryTermContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_queryTerm); this.state = 1894; if (!(this.precpred(this._ctx, 1))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 1)"); } this.state = 1895; if (!(!this.legacy_setops_precedence_enabled)) { throw this.createFailedPredicateException("!this.legacy_setops_precedence_enabled"); } this.state = 1896; _localctx._operator = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_EXCEPT || _la === SparkSqlParser.KW_SETMINUS || _la === SparkSqlParser.KW_UNION)) { _localctx._operator = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 1898; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ALL || _la === SparkSqlParser.KW_DISTINCT) { { this.state = 1897; this.setQuantifier(); } } this.state = 1900; _localctx._right = this.queryTerm(2); } break; } } } this.state = 1905; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 217, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.unrollRecursionContexts(_parentctx); } return _localctx; } // @RuleVersion(0) public queryPrimary(): QueryPrimaryContext { let _localctx: QueryPrimaryContext = new QueryPrimaryContext(this._ctx, this.state); this.enterRule(_localctx, 98, SparkSqlParser.RULE_queryPrimary); try { this.state = 1915; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_MAP: case SparkSqlParser.KW_REDUCE: case SparkSqlParser.KW_SELECT: this.enterOuterAlt(_localctx, 1); { this.state = 1906; this.querySpecification(); } break; case SparkSqlParser.KW_FROM: this.enterOuterAlt(_localctx, 2); { this.state = 1907; this.fromStatement(); } break; case SparkSqlParser.KW_TABLE: this.enterOuterAlt(_localctx, 3); { this.state = 1908; this.match(SparkSqlParser.KW_TABLE); this.state = 1909; this.tableName(); } break; case SparkSqlParser.KW_VALUES: this.enterOuterAlt(_localctx, 4); { this.state = 1910; this.inlineTable(); } break; case SparkSqlParser.LEFT_PAREN: this.enterOuterAlt(_localctx, 5); { this.state = 1911; this.match(SparkSqlParser.LEFT_PAREN); this.state = 1912; this.query(); this.state = 1913; this.match(SparkSqlParser.RIGHT_PAREN); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public sortItem(): SortItemContext { let _localctx: SortItemContext = new SortItemContext(this._ctx, this.state); this.enterRule(_localctx, 100, SparkSqlParser.RULE_sortItem); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 1917; this.expression(); this.state = 1919; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 219, this._ctx) ) { case 1: { this.state = 1918; _localctx._ordering = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ASC || _la === SparkSqlParser.KW_DESC)) { _localctx._ordering = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; } this.state = 1923; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 220, this._ctx) ) { case 1: { this.state = 1921; this.match(SparkSqlParser.KW_NULLS); this.state = 1922; _localctx._nullOrder = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FIRST || _la === SparkSqlParser.KW_LAST)) { _localctx._nullOrder = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public fromStatement(): FromStatementContext { let _localctx: FromStatementContext = new FromStatementContext(this._ctx, this.state); this.enterRule(_localctx, 102, SparkSqlParser.RULE_fromStatement); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 1925; this.fromClause(); this.state = 1927; this._errHandler.sync(this); _alt = 1; do { switch (_alt) { case 1: { { this.state = 1926; this.fromStatementBody(); } } break; default: throw new NoViableAltException(this); } this.state = 1929; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 221, this._ctx); } while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public fromStatementBody(): FromStatementBodyContext { let _localctx: FromStatementBodyContext = new FromStatementBodyContext(this._ctx, this.state); this.enterRule(_localctx, 104, SparkSqlParser.RULE_fromStatementBody); try { let _alt: number; this.state = 1958; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 228, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1931; this.transformClause(); this.state = 1933; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 222, this._ctx) ) { case 1: { this.state = 1932; this.whereClause(); } break; } this.state = 1935; this.queryOrganization(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1937; this.selectClause(); this.state = 1941; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 223, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 1938; this.lateralView(); } } } this.state = 1943; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 223, this._ctx); } this.state = 1945; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 224, this._ctx) ) { case 1: { this.state = 1944; this.whereClause(); } break; } this.state = 1948; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 225, this._ctx) ) { case 1: { this.state = 1947; this.aggregationClause(); } break; } this.state = 1951; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 226, this._ctx) ) { case 1: { this.state = 1950; this.havingClause(); } break; } this.state = 1954; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 227, this._ctx) ) { case 1: { this.state = 1953; this.windowClause(); } break; } this.state = 1956; this.queryOrganization(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public querySpecification(): QuerySpecificationContext { let _localctx: QuerySpecificationContext = new QuerySpecificationContext(this._ctx, this.state); this.enterRule(_localctx, 106, SparkSqlParser.RULE_querySpecification); try { let _alt: number; this.state = 2004; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 241, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 1960; this.transformClause(); this.state = 1962; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 229, this._ctx) ) { case 1: { this.state = 1961; this.fromClause(); } break; } this.state = 1967; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 230, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 1964; this.lateralView(); } } } this.state = 1969; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 230, this._ctx); } this.state = 1971; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 231, this._ctx) ) { case 1: { this.state = 1970; this.whereClause(); } break; } this.state = 1974; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 232, this._ctx) ) { case 1: { this.state = 1973; this.aggregationClause(); } break; } this.state = 1977; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 233, this._ctx) ) { case 1: { this.state = 1976; this.havingClause(); } break; } this.state = 1980; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 234, this._ctx) ) { case 1: { this.state = 1979; this.windowClause(); } break; } } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 1982; this.selectClause(); this.state = 1984; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 235, this._ctx) ) { case 1: { this.state = 1983; this.fromClause(); } break; } this.state = 1989; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 236, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 1986; this.lateralView(); } } } this.state = 1991; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 236, this._ctx); } this.state = 1993; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 237, this._ctx) ) { case 1: { this.state = 1992; this.whereClause(); } break; } this.state = 1996; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 238, this._ctx) ) { case 1: { this.state = 1995; this.aggregationClause(); } break; } this.state = 1999; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 239, this._ctx) ) { case 1: { this.state = 1998; this.havingClause(); } break; } this.state = 2002; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 240, this._ctx) ) { case 1: { this.state = 2001; this.windowClause(); } break; } } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public transformClause(): TransformClauseContext { let _localctx: TransformClauseContext = new TransformClauseContext(this._ctx, this.state); this.enterRule(_localctx, 108, SparkSqlParser.RULE_transformClause); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2025; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_SELECT: { this.state = 2006; this.match(SparkSqlParser.KW_SELECT); this.state = 2007; _localctx._kind = this.match(SparkSqlParser.KW_TRANSFORM); this.state = 2008; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2010; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 242, this._ctx) ) { case 1: { this.state = 2009; this.setQuantifier(); } break; } this.state = 2012; this.expressionSeq(); this.state = 2013; this.match(SparkSqlParser.RIGHT_PAREN); } break; case SparkSqlParser.KW_MAP: { this.state = 2015; _localctx._kind = this.match(SparkSqlParser.KW_MAP); this.state = 2017; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 243, this._ctx) ) { case 1: { this.state = 2016; this.setQuantifier(); } break; } this.state = 2019; this.expressionSeq(); } break; case SparkSqlParser.KW_REDUCE: { this.state = 2020; _localctx._kind = this.match(SparkSqlParser.KW_REDUCE); this.state = 2022; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 244, this._ctx) ) { case 1: { this.state = 2021; this.setQuantifier(); } break; } this.state = 2024; this.expressionSeq(); } break; default: throw new NoViableAltException(this); } this.state = 2028; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ROW) { { this.state = 2027; _localctx._inRowFormat = this.rowFormat(); } } this.state = 2032; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_RECORDWRITER) { { this.state = 2030; this.match(SparkSqlParser.KW_RECORDWRITER); this.state = 2031; _localctx._recordWriter = this.stringLit(); } } this.state = 2034; this.match(SparkSqlParser.KW_USING); this.state = 2035; _localctx._script = this.stringLit(); this.state = 2048; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 250, this._ctx) ) { case 1: { this.state = 2036; this.match(SparkSqlParser.KW_AS); this.state = 2046; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 249, this._ctx) ) { case 1: { this.state = 2037; this.identifierSeq(); } break; case 2: { this.state = 2038; this.colTypeList(); } break; case 3: { { this.state = 2039; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2042; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 248, this._ctx) ) { case 1: { this.state = 2040; this.identifierSeq(); } break; case 2: { this.state = 2041; this.colTypeList(); } break; } this.state = 2044; this.match(SparkSqlParser.RIGHT_PAREN); } } break; } } break; } this.state = 2051; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 251, this._ctx) ) { case 1: { this.state = 2050; _localctx._outRowFormat = this.rowFormat(); } break; } this.state = 2055; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 252, this._ctx) ) { case 1: { this.state = 2053; this.match(SparkSqlParser.KW_RECORDREADER); this.state = 2054; _localctx._recordReader = this.stringLit(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public selectClause(): SelectClauseContext { let _localctx: SelectClauseContext = new SelectClauseContext(this._ctx, this.state); this.enterRule(_localctx, 110, SparkSqlParser.RULE_selectClause); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 2057; this.match(SparkSqlParser.KW_SELECT); this.state = 2061; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 253, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2058; _localctx._hint = this.hint(); _localctx._hints.push(_localctx._hint); } } } this.state = 2063; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 253, this._ctx); } this.state = 2065; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 254, this._ctx) ) { case 1: { this.state = 2064; this.setQuantifier(); } break; } this.state = 2067; this.namedExpressionSeq(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public setClause(): SetClauseContext { let _localctx: SetClauseContext = new SetClauseContext(this._ctx, this.state); this.enterRule(_localctx, 112, SparkSqlParser.RULE_setClause); try { this.enterOuterAlt(_localctx, 1); { this.state = 2069; this.match(SparkSqlParser.KW_SET); this.state = 2070; this.assignmentList(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public matchedClause(): MatchedClauseContext { let _localctx: MatchedClauseContext = new MatchedClauseContext(this._ctx, this.state); this.enterRule(_localctx, 114, SparkSqlParser.RULE_matchedClause); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2072; this.match(SparkSqlParser.KW_WHEN); this.state = 2073; this.match(SparkSqlParser.KW_MATCHED); this.state = 2076; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_AND) { { this.state = 2074; this.match(SparkSqlParser.KW_AND); this.state = 2075; _localctx._matchedCond = this.booleanExpression(0); } } this.state = 2078; this.match(SparkSqlParser.KW_THEN); this.state = 2079; this.matchedAction(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public notMatchedClause(): NotMatchedClauseContext { let _localctx: NotMatchedClauseContext = new NotMatchedClauseContext(this._ctx, this.state); this.enterRule(_localctx, 116, SparkSqlParser.RULE_notMatchedClause); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2081; this.match(SparkSqlParser.KW_WHEN); this.state = 2082; this.match(SparkSqlParser.KW_NOT); this.state = 2083; this.match(SparkSqlParser.KW_MATCHED); this.state = 2086; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_BY) { { this.state = 2084; this.match(SparkSqlParser.KW_BY); this.state = 2085; this.match(SparkSqlParser.KW_TARGET); } } this.state = 2090; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_AND) { { this.state = 2088; this.match(SparkSqlParser.KW_AND); this.state = 2089; _localctx._notMatchedCond = this.booleanExpression(0); } } this.state = 2092; this.match(SparkSqlParser.KW_THEN); this.state = 2093; this.notMatchedAction(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public notMatchedBySourceClause(): NotMatchedBySourceClauseContext { let _localctx: NotMatchedBySourceClauseContext = new NotMatchedBySourceClauseContext(this._ctx, this.state); this.enterRule(_localctx, 118, SparkSqlParser.RULE_notMatchedBySourceClause); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2095; this.match(SparkSqlParser.KW_WHEN); this.state = 2096; this.match(SparkSqlParser.KW_NOT); this.state = 2097; this.match(SparkSqlParser.KW_MATCHED); this.state = 2098; this.match(SparkSqlParser.KW_BY); this.state = 2099; this.match(SparkSqlParser.KW_SOURCE); this.state = 2102; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_AND) { { this.state = 2100; this.match(SparkSqlParser.KW_AND); this.state = 2101; _localctx._notMatchedBySourceCond = this.booleanExpression(0); } } this.state = 2104; this.match(SparkSqlParser.KW_THEN); this.state = 2105; this.notMatchedBySourceAction(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public matchedAction(): MatchedActionContext { let _localctx: MatchedActionContext = new MatchedActionContext(this._ctx, this.state); this.enterRule(_localctx, 120, SparkSqlParser.RULE_matchedAction); try { this.state = 2114; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 259, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2107; this.match(SparkSqlParser.KW_DELETE); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2108; this.match(SparkSqlParser.KW_UPDATE); this.state = 2109; this.match(SparkSqlParser.KW_SET); this.state = 2110; this.match(SparkSqlParser.ASTERISK); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 2111; this.match(SparkSqlParser.KW_UPDATE); this.state = 2112; this.match(SparkSqlParser.KW_SET); this.state = 2113; this.assignmentList(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public notMatchedAction(): NotMatchedActionContext { let _localctx: NotMatchedActionContext = new NotMatchedActionContext(this._ctx, this.state); this.enterRule(_localctx, 122, SparkSqlParser.RULE_notMatchedAction); let _la: number; try { this.state = 2134; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 261, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2116; this.match(SparkSqlParser.KW_INSERT); this.state = 2117; this.match(SparkSqlParser.ASTERISK); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2118; this.match(SparkSqlParser.KW_INSERT); this.state = 2119; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2120; this.multipartIdentifierList(); this.state = 2121; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2122; this.match(SparkSqlParser.KW_VALUES); this.state = 2123; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2124; this.expression(); this.state = 2129; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2125; this.match(SparkSqlParser.COMMA); this.state = 2126; this.expression(); } } this.state = 2131; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2132; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public notMatchedBySourceAction(): NotMatchedBySourceActionContext { let _localctx: NotMatchedBySourceActionContext = new NotMatchedBySourceActionContext(this._ctx, this.state); this.enterRule(_localctx, 124, SparkSqlParser.RULE_notMatchedBySourceAction); try { this.state = 2140; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_DELETE: this.enterOuterAlt(_localctx, 1); { this.state = 2136; this.match(SparkSqlParser.KW_DELETE); } break; case SparkSqlParser.KW_UPDATE: this.enterOuterAlt(_localctx, 2); { this.state = 2137; this.match(SparkSqlParser.KW_UPDATE); this.state = 2138; this.match(SparkSqlParser.KW_SET); this.state = 2139; this.assignmentList(); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public assignmentList(): AssignmentListContext { let _localctx: AssignmentListContext = new AssignmentListContext(this._ctx, this.state); this.enterRule(_localctx, 126, SparkSqlParser.RULE_assignmentList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2142; this.assignment(); this.state = 2147; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2143; this.match(SparkSqlParser.COMMA); this.state = 2144; this.assignment(); } } this.state = 2149; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public assignment(): AssignmentContext { let _localctx: AssignmentContext = new AssignmentContext(this._ctx, this.state); this.enterRule(_localctx, 128, SparkSqlParser.RULE_assignment); try { this.enterOuterAlt(_localctx, 1); { this.state = 2150; _localctx._key = this.multipartIdentifier(); this.state = 2151; this.match(SparkSqlParser.EQ); this.state = 2152; _localctx._value = this.expression(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public whereClause(): WhereClauseContext { let _localctx: WhereClauseContext = new WhereClauseContext(this._ctx, this.state); this.enterRule(_localctx, 130, SparkSqlParser.RULE_whereClause); try { this.enterOuterAlt(_localctx, 1); { this.state = 2154; this.match(SparkSqlParser.KW_WHERE); this.state = 2155; this.booleanExpression(0); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public havingClause(): HavingClauseContext { let _localctx: HavingClauseContext = new HavingClauseContext(this._ctx, this.state); this.enterRule(_localctx, 132, SparkSqlParser.RULE_havingClause); try { this.enterOuterAlt(_localctx, 1); { this.state = 2157; this.match(SparkSqlParser.KW_HAVING); this.state = 2158; this.booleanExpression(0); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public hint(): HintContext { let _localctx: HintContext = new HintContext(this._ctx, this.state); this.enterRule(_localctx, 134, SparkSqlParser.RULE_hint); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 2160; this.match(SparkSqlParser.HENT_START); this.state = 2161; _localctx._hintStatement = this.hintStatement(); _localctx._hintStatements.push(_localctx._hintStatement); this.state = 2168; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 265, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2163; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 264, this._ctx) ) { case 1: { this.state = 2162; this.match(SparkSqlParser.COMMA); } break; } this.state = 2165; _localctx._hintStatement = this.hintStatement(); _localctx._hintStatements.push(_localctx._hintStatement); } } } this.state = 2170; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 265, this._ctx); } this.state = 2171; this.match(SparkSqlParser.HENT_END); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public hintStatement(): HintStatementContext { let _localctx: HintStatementContext = new HintStatementContext(this._ctx, this.state); this.enterRule(_localctx, 136, SparkSqlParser.RULE_hintStatement); let _la: number; try { this.state = 2186; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 267, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2173; _localctx._hintName = this.identifier(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2174; _localctx._hintName = this.identifier(); this.state = 2175; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2176; _localctx._primaryExpression = this.primaryExpression(0); _localctx._parameters.push(_localctx._primaryExpression); this.state = 2181; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2177; this.match(SparkSqlParser.COMMA); this.state = 2178; _localctx._primaryExpression = this.primaryExpression(0); _localctx._parameters.push(_localctx._primaryExpression); } } this.state = 2183; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2184; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public fromClause(): FromClauseContext { let _localctx: FromClauseContext = new FromClauseContext(this._ctx, this.state); this.enterRule(_localctx, 138, SparkSqlParser.RULE_fromClause); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 2188; this.match(SparkSqlParser.KW_FROM); this.state = 2189; this.relation(); this.state = 2194; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 268, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2190; this.match(SparkSqlParser.COMMA); this.state = 2191; this.relation(); } } } this.state = 2196; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 268, this._ctx); } this.state = 2200; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 269, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2197; this.lateralView(); } } } this.state = 2202; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 269, this._ctx); } this.state = 2204; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 270, this._ctx) ) { case 1: { this.state = 2203; this.pivotClause(); } break; } this.state = 2207; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 271, this._ctx) ) { case 1: { this.state = 2206; this.unpivotClause(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public functionKind(): FunctionKindContext { let _localctx: FunctionKindContext = new FunctionKindContext(this._ctx, this.state); this.enterRule(_localctx, 140, SparkSqlParser.RULE_functionKind); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2209; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ALL || _la === SparkSqlParser.KW_SYSTEM || _la === SparkSqlParser.KW_USER)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public temporalClause(): TemporalClauseContext { let _localctx: TemporalClauseContext = new TemporalClauseContext(this._ctx, this.state); this.enterRule(_localctx, 142, SparkSqlParser.RULE_temporalClause); let _la: number; try { this.state = 2225; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 274, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2212; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_FOR) { { this.state = 2211; this.match(SparkSqlParser.KW_FOR); } } this.state = 2214; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_SYSTEM_VERSION || _la === SparkSqlParser.KW_VERSION)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 2215; this.match(SparkSqlParser.KW_AS); this.state = 2216; this.match(SparkSqlParser.KW_OF); this.state = 2217; this.version(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2219; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_FOR) { { this.state = 2218; this.match(SparkSqlParser.KW_FOR); } } this.state = 2221; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_SYSTEM_TIME || _la === SparkSqlParser.KW_TIMESTAMP)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 2222; this.match(SparkSqlParser.KW_AS); this.state = 2223; this.match(SparkSqlParser.KW_OF); this.state = 2224; _localctx._timestamp = this.valueExpression(0); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public aggregationClause(): AggregationClauseContext { let _localctx: AggregationClauseContext = new AggregationClauseContext(this._ctx, this.state); this.enterRule(_localctx, 144, SparkSqlParser.RULE_aggregationClause); let _la: number; try { let _alt: number; this.state = 2266; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 279, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2227; this.match(SparkSqlParser.KW_GROUP); this.state = 2228; this.match(SparkSqlParser.KW_BY); this.state = 2229; _localctx._groupByClause = this.groupByClause(); _localctx._groupingExpressionsWithGroupingAnalytics.push(_localctx._groupByClause); this.state = 2234; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 275, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2230; this.match(SparkSqlParser.COMMA); this.state = 2231; _localctx._groupByClause = this.groupByClause(); _localctx._groupingExpressionsWithGroupingAnalytics.push(_localctx._groupByClause); } } } this.state = 2236; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 275, this._ctx); } } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2237; this.match(SparkSqlParser.KW_GROUP); this.state = 2238; this.match(SparkSqlParser.KW_BY); this.state = 2239; _localctx._expression = this.expression(); _localctx._groupingExpressions.push(_localctx._expression); this.state = 2244; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 276, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2240; this.match(SparkSqlParser.COMMA); this.state = 2241; _localctx._expression = this.expression(); _localctx._groupingExpressions.push(_localctx._expression); } } } this.state = 2246; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 276, this._ctx); } this.state = 2264; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 278, this._ctx) ) { case 1: { this.state = 2247; this.match(SparkSqlParser.KW_WITH); this.state = 2248; _localctx._kind = this.match(SparkSqlParser.KW_ROLLUP); } break; case 2: { this.state = 2249; this.match(SparkSqlParser.KW_WITH); this.state = 2250; _localctx._kind = this.match(SparkSqlParser.KW_CUBE); } break; case 3: { this.state = 2251; _localctx._kind = this.match(SparkSqlParser.KW_GROUPING); this.state = 2252; this.match(SparkSqlParser.KW_SETS); this.state = 2253; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2254; this.groupingSet(); this.state = 2259; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2255; this.match(SparkSqlParser.COMMA); this.state = 2256; this.groupingSet(); } } this.state = 2261; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2262; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public groupByClause(): GroupByClauseContext { let _localctx: GroupByClauseContext = new GroupByClauseContext(this._ctx, this.state); this.enterRule(_localctx, 146, SparkSqlParser.RULE_groupByClause); try { this.state = 2270; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 280, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2268; this.groupingAnalytics(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2269; this.expression(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public groupingAnalytics(): GroupingAnalyticsContext { let _localctx: GroupingAnalyticsContext = new GroupingAnalyticsContext(this._ctx, this.state); this.enterRule(_localctx, 148, SparkSqlParser.RULE_groupingAnalytics); let _la: number; try { this.state = 2297; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_CUBE: case SparkSqlParser.KW_ROLLUP: this.enterOuterAlt(_localctx, 1); { this.state = 2272; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_CUBE || _la === SparkSqlParser.KW_ROLLUP)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 2273; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2274; this.groupingSet(); this.state = 2279; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2275; this.match(SparkSqlParser.COMMA); this.state = 2276; this.groupingSet(); } } this.state = 2281; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2282; this.match(SparkSqlParser.RIGHT_PAREN); } break; case SparkSqlParser.KW_GROUPING: this.enterOuterAlt(_localctx, 2); { this.state = 2284; this.match(SparkSqlParser.KW_GROUPING); this.state = 2285; this.match(SparkSqlParser.KW_SETS); this.state = 2286; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2287; this.groupingElement(); this.state = 2292; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2288; this.match(SparkSqlParser.COMMA); this.state = 2289; this.groupingElement(); } } this.state = 2294; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2295; this.match(SparkSqlParser.RIGHT_PAREN); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public groupingElement(): GroupingElementContext { let _localctx: GroupingElementContext = new GroupingElementContext(this._ctx, this.state); this.enterRule(_localctx, 150, SparkSqlParser.RULE_groupingElement); try { this.state = 2301; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 284, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2299; this.groupingAnalytics(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2300; this.groupingSet(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public groupingSet(): GroupingSetContext { let _localctx: GroupingSetContext = new GroupingSetContext(this._ctx, this.state); this.enterRule(_localctx, 152, SparkSqlParser.RULE_groupingSet); let _la: number; try { this.state = 2316; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 287, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2303; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2312; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 286, this._ctx) ) { case 1: { this.state = 2304; this.expression(); this.state = 2309; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2305; this.match(SparkSqlParser.COMMA); this.state = 2306; this.expression(); } } this.state = 2311; this._errHandler.sync(this); _la = this._input.LA(1); } } break; } this.state = 2314; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2315; this.expression(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public pivotClause(): PivotClauseContext { let _localctx: PivotClauseContext = new PivotClauseContext(this._ctx, this.state); this.enterRule(_localctx, 154, SparkSqlParser.RULE_pivotClause); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2318; this.match(SparkSqlParser.KW_PIVOT); this.state = 2319; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2320; _localctx._aggregates = this.namedExpressionSeq(); this.state = 2321; this.match(SparkSqlParser.KW_FOR); this.state = 2322; this.pivotColumn(); this.state = 2323; this.match(SparkSqlParser.KW_IN); this.state = 2324; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2325; _localctx._pivotValue = this.pivotValue(); _localctx._pivotValues.push(_localctx._pivotValue); this.state = 2330; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2326; this.match(SparkSqlParser.COMMA); this.state = 2327; _localctx._pivotValue = this.pivotValue(); _localctx._pivotValues.push(_localctx._pivotValue); } } this.state = 2332; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2333; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2334; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public pivotColumn(): PivotColumnContext { let _localctx: PivotColumnContext = new PivotColumnContext(this._ctx, this.state); this.enterRule(_localctx, 156, SparkSqlParser.RULE_pivotColumn); let _la: number; try { this.state = 2348; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 290, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2336; _localctx._identifier = this.identifier(); _localctx._identifiers.push(_localctx._identifier); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2337; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2338; _localctx._identifier = this.identifier(); _localctx._identifiers.push(_localctx._identifier); this.state = 2343; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2339; this.match(SparkSqlParser.COMMA); this.state = 2340; _localctx._identifier = this.identifier(); _localctx._identifiers.push(_localctx._identifier); } } this.state = 2345; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2346; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public pivotValue(): PivotValueContext { let _localctx: PivotValueContext = new PivotValueContext(this._ctx, this.state); this.enterRule(_localctx, 158, SparkSqlParser.RULE_pivotValue); try { this.enterOuterAlt(_localctx, 1); { this.state = 2350; this.expression(); this.state = 2355; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 292, this._ctx) ) { case 1: { this.state = 2352; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 291, this._ctx) ) { case 1: { this.state = 2351; this.match(SparkSqlParser.KW_AS); } break; } this.state = 2354; this.identifier(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotClause(): UnpivotClauseContext { let _localctx: UnpivotClauseContext = new UnpivotClauseContext(this._ctx, this.state); this.enterRule(_localctx, 160, SparkSqlParser.RULE_unpivotClause); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2357; this.match(SparkSqlParser.KW_UNPIVOT); this.state = 2359; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_EXCLUDE || _la === SparkSqlParser.KW_INCLUDE) { { this.state = 2358; _localctx._nullOperator = this.unpivotNullClause(); } } this.state = 2361; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2362; _localctx._operator = this.unpivotOperator(); this.state = 2363; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2368; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 295, this._ctx) ) { case 1: { this.state = 2365; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 294, this._ctx) ) { case 1: { this.state = 2364; this.match(SparkSqlParser.KW_AS); } break; } this.state = 2367; this.identifier(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotNullClause(): UnpivotNullClauseContext { let _localctx: UnpivotNullClauseContext = new UnpivotNullClauseContext(this._ctx, this.state); this.enterRule(_localctx, 162, SparkSqlParser.RULE_unpivotNullClause); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2370; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_EXCLUDE || _la === SparkSqlParser.KW_INCLUDE)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 2371; this.match(SparkSqlParser.KW_NULLS); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotOperator(): UnpivotOperatorContext { let _localctx: UnpivotOperatorContext = new UnpivotOperatorContext(this._ctx, this.state); this.enterRule(_localctx, 164, SparkSqlParser.RULE_unpivotOperator); try { this.enterOuterAlt(_localctx, 1); { this.state = 2375; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 296, this._ctx) ) { case 1: { this.state = 2373; this.unpivotSingleValueColumnClause(); } break; case 2: { this.state = 2374; this.unpivotMultiValueColumnClause(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotSingleValueColumnClause(): UnpivotSingleValueColumnClauseContext { let _localctx: UnpivotSingleValueColumnClauseContext = new UnpivotSingleValueColumnClauseContext(this._ctx, this.state); this.enterRule(_localctx, 166, SparkSqlParser.RULE_unpivotSingleValueColumnClause); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2377; this.unpivotValueColumn(); this.state = 2378; this.match(SparkSqlParser.KW_FOR); this.state = 2379; this.unpivotNameColumn(); this.state = 2380; this.match(SparkSqlParser.KW_IN); this.state = 2381; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2382; _localctx._unpivotColumnAndAlias = this.unpivotColumnAndAlias(); _localctx._unpivotColumns.push(_localctx._unpivotColumnAndAlias); this.state = 2387; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2383; this.match(SparkSqlParser.COMMA); this.state = 2384; _localctx._unpivotColumnAndAlias = this.unpivotColumnAndAlias(); _localctx._unpivotColumns.push(_localctx._unpivotColumnAndAlias); } } this.state = 2389; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2390; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotMultiValueColumnClause(): UnpivotMultiValueColumnClauseContext { let _localctx: UnpivotMultiValueColumnClauseContext = new UnpivotMultiValueColumnClauseContext(this._ctx, this.state); this.enterRule(_localctx, 168, SparkSqlParser.RULE_unpivotMultiValueColumnClause); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2392; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2393; _localctx._unpivotValueColumn = this.unpivotValueColumn(); _localctx._unpivotValueColumns.push(_localctx._unpivotValueColumn); this.state = 2398; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2394; this.match(SparkSqlParser.COMMA); this.state = 2395; _localctx._unpivotValueColumn = this.unpivotValueColumn(); _localctx._unpivotValueColumns.push(_localctx._unpivotValueColumn); } } this.state = 2400; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2401; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2402; this.match(SparkSqlParser.KW_FOR); this.state = 2403; this.unpivotNameColumn(); this.state = 2404; this.match(SparkSqlParser.KW_IN); this.state = 2405; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2406; _localctx._unpivotColumnSet = this.unpivotColumnSet(); _localctx._unpivotColumnSets.push(_localctx._unpivotColumnSet); this.state = 2411; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2407; this.match(SparkSqlParser.COMMA); this.state = 2408; _localctx._unpivotColumnSet = this.unpivotColumnSet(); _localctx._unpivotColumnSets.push(_localctx._unpivotColumnSet); } } this.state = 2413; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2414; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotColumnSet(): UnpivotColumnSetContext { let _localctx: UnpivotColumnSetContext = new UnpivotColumnSetContext(this._ctx, this.state); this.enterRule(_localctx, 170, SparkSqlParser.RULE_unpivotColumnSet); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2416; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2417; _localctx._unpivotColumn = this.unpivotColumn(); _localctx._unpivotColumns.push(_localctx._unpivotColumn); this.state = 2422; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2418; this.match(SparkSqlParser.COMMA); this.state = 2419; _localctx._unpivotColumn = this.unpivotColumn(); _localctx._unpivotColumns.push(_localctx._unpivotColumn); } } this.state = 2424; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2425; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2427; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 301, this._ctx) ) { case 1: { this.state = 2426; this.unpivotAlias(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotValueColumn(): UnpivotValueColumnContext { let _localctx: UnpivotValueColumnContext = new UnpivotValueColumnContext(this._ctx, this.state); this.enterRule(_localctx, 172, SparkSqlParser.RULE_unpivotValueColumn); try { this.enterOuterAlt(_localctx, 1); { this.state = 2429; this.identifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotNameColumn(): UnpivotNameColumnContext { let _localctx: UnpivotNameColumnContext = new UnpivotNameColumnContext(this._ctx, this.state); this.enterRule(_localctx, 174, SparkSqlParser.RULE_unpivotNameColumn); try { this.enterOuterAlt(_localctx, 1); { this.state = 2431; this.identifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotColumnAndAlias(): UnpivotColumnAndAliasContext { let _localctx: UnpivotColumnAndAliasContext = new UnpivotColumnAndAliasContext(this._ctx, this.state); this.enterRule(_localctx, 176, SparkSqlParser.RULE_unpivotColumnAndAlias); try { this.enterOuterAlt(_localctx, 1); { this.state = 2433; this.unpivotColumn(); this.state = 2435; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 302, this._ctx) ) { case 1: { this.state = 2434; this.unpivotAlias(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotColumn(): UnpivotColumnContext { let _localctx: UnpivotColumnContext = new UnpivotColumnContext(this._ctx, this.state); this.enterRule(_localctx, 178, SparkSqlParser.RULE_unpivotColumn); try { this.enterOuterAlt(_localctx, 1); { this.state = 2437; this.multipartIdentifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unpivotAlias(): UnpivotAliasContext { let _localctx: UnpivotAliasContext = new UnpivotAliasContext(this._ctx, this.state); this.enterRule(_localctx, 180, SparkSqlParser.RULE_unpivotAlias); try { this.enterOuterAlt(_localctx, 1); { this.state = 2440; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 303, this._ctx) ) { case 1: { this.state = 2439; this.match(SparkSqlParser.KW_AS); } break; } this.state = 2442; this.identifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public ifNotExists(): IfNotExistsContext { let _localctx: IfNotExistsContext = new IfNotExistsContext(this._ctx, this.state); this.enterRule(_localctx, 182, SparkSqlParser.RULE_ifNotExists); try { this.enterOuterAlt(_localctx, 1); { this.state = 2444; this.match(SparkSqlParser.KW_IF); this.state = 2445; this.match(SparkSqlParser.KW_NOT); this.state = 2446; this.match(SparkSqlParser.KW_EXISTS); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public ifExists(): IfExistsContext { let _localctx: IfExistsContext = new IfExistsContext(this._ctx, this.state); this.enterRule(_localctx, 184, SparkSqlParser.RULE_ifExists); try { this.enterOuterAlt(_localctx, 1); { this.state = 2448; this.match(SparkSqlParser.KW_IF); this.state = 2449; this.match(SparkSqlParser.KW_EXISTS); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public lateralView(): LateralViewContext { let _localctx: LateralViewContext = new LateralViewContext(this._ctx, this.state); this.enterRule(_localctx, 186, SparkSqlParser.RULE_lateralView); let _la: number; try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 2451; this.match(SparkSqlParser.KW_LATERAL); this.state = 2452; this.match(SparkSqlParser.KW_VIEW); this.state = 2454; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 304, this._ctx) ) { case 1: { this.state = 2453; this.match(SparkSqlParser.KW_OUTER); } break; } this.state = 2456; this.viewName(); this.state = 2457; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2466; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 306, this._ctx) ) { case 1: { this.state = 2458; this.expression(); this.state = 2463; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2459; this.match(SparkSqlParser.COMMA); this.state = 2460; this.expression(); } } this.state = 2465; this._errHandler.sync(this); _la = this._input.LA(1); } } break; } this.state = 2468; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2469; this.tableAlias(); this.state = 2481; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 309, this._ctx) ) { case 1: { this.state = 2471; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 307, this._ctx) ) { case 1: { this.state = 2470; this.match(SparkSqlParser.KW_AS); } break; } this.state = 2473; _localctx._identifier = this.identifier(); _localctx._colName.push(_localctx._identifier); this.state = 2478; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 308, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2474; this.match(SparkSqlParser.COMMA); this.state = 2475; _localctx._identifier = this.identifier(); _localctx._colName.push(_localctx._identifier); } } } this.state = 2480; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 308, this._ctx); } } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public setQuantifier(): SetQuantifierContext { let _localctx: SetQuantifierContext = new SetQuantifierContext(this._ctx, this.state); this.enterRule(_localctx, 188, SparkSqlParser.RULE_setQuantifier); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2483; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ALL || _la === SparkSqlParser.KW_DISTINCT)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public relation(): RelationContext { let _localctx: RelationContext = new RelationContext(this._ctx, this.state); this.enterRule(_localctx, 190, SparkSqlParser.RULE_relation); try { let _alt: number; this.state = 2496; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 312, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2486; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 310, this._ctx) ) { case 1: { this.state = 2485; this.match(SparkSqlParser.KW_LATERAL); } break; } this.state = 2488; this.relationPrimary(); this.state = 2492; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 311, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2489; this.relationExtension(); } } } this.state = 2494; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 311, this._ctx); } } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2495; this.tableName(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public relationExtension(): RelationExtensionContext { let _localctx: RelationExtensionContext = new RelationExtensionContext(this._ctx, this.state); this.enterRule(_localctx, 192, SparkSqlParser.RULE_relationExtension); try { this.state = 2501; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_ANTI: case SparkSqlParser.KW_CROSS: case SparkSqlParser.KW_FULL: case SparkSqlParser.KW_INNER: case SparkSqlParser.KW_JOIN: case SparkSqlParser.KW_LEFT: case SparkSqlParser.KW_NATURAL: case SparkSqlParser.KW_RIGHT: case SparkSqlParser.KW_SEMI: this.enterOuterAlt(_localctx, 1); { this.state = 2498; this.joinRelation(); } break; case SparkSqlParser.KW_PIVOT: this.enterOuterAlt(_localctx, 2); { this.state = 2499; this.pivotClause(); } break; case SparkSqlParser.KW_UNPIVOT: this.enterOuterAlt(_localctx, 3); { this.state = 2500; this.unpivotClause(); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public joinRelation(): JoinRelationContext { let _localctx: JoinRelationContext = new JoinRelationContext(this._ctx, this.state); this.enterRule(_localctx, 194, SparkSqlParser.RULE_joinRelation); try { this.state = 2520; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_ANTI: case SparkSqlParser.KW_CROSS: case SparkSqlParser.KW_FULL: case SparkSqlParser.KW_INNER: case SparkSqlParser.KW_JOIN: case SparkSqlParser.KW_LEFT: case SparkSqlParser.KW_RIGHT: case SparkSqlParser.KW_SEMI: this.enterOuterAlt(_localctx, 1); { { this.state = 2503; this.joinType(); } this.state = 2504; this.match(SparkSqlParser.KW_JOIN); this.state = 2506; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 314, this._ctx) ) { case 1: { this.state = 2505; this.match(SparkSqlParser.KW_LATERAL); } break; } this.state = 2508; _localctx._right = this.relationPrimary(); this.state = 2510; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 315, this._ctx) ) { case 1: { this.state = 2509; this.joinCriteria(); } break; } } break; case SparkSqlParser.KW_NATURAL: this.enterOuterAlt(_localctx, 2); { this.state = 2512; this.match(SparkSqlParser.KW_NATURAL); this.state = 2513; this.joinType(); this.state = 2514; this.match(SparkSqlParser.KW_JOIN); this.state = 2516; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 316, this._ctx) ) { case 1: { this.state = 2515; this.match(SparkSqlParser.KW_LATERAL); } break; } this.state = 2518; _localctx._right = this.relationPrimary(); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public joinType(): JoinTypeContext { let _localctx: JoinTypeContext = new JoinTypeContext(this._ctx, this.state); this.enterRule(_localctx, 196, SparkSqlParser.RULE_joinType); let _la: number; try { this.state = 2546; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 324, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2523; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_INNER) { { this.state = 2522; this.match(SparkSqlParser.KW_INNER); } } } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2525; this.match(SparkSqlParser.KW_CROSS); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 2526; this.match(SparkSqlParser.KW_LEFT); this.state = 2528; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OUTER) { { this.state = 2527; this.match(SparkSqlParser.KW_OUTER); } } } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 2531; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_LEFT) { { this.state = 2530; this.match(SparkSqlParser.KW_LEFT); } } this.state = 2533; this.match(SparkSqlParser.KW_SEMI); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 2534; this.match(SparkSqlParser.KW_RIGHT); this.state = 2536; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OUTER) { { this.state = 2535; this.match(SparkSqlParser.KW_OUTER); } } } break; case 6: this.enterOuterAlt(_localctx, 6); { this.state = 2538; this.match(SparkSqlParser.KW_FULL); this.state = 2540; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OUTER) { { this.state = 2539; this.match(SparkSqlParser.KW_OUTER); } } } break; case 7: this.enterOuterAlt(_localctx, 7); { this.state = 2543; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_LEFT) { { this.state = 2542; this.match(SparkSqlParser.KW_LEFT); } } this.state = 2545; this.match(SparkSqlParser.KW_ANTI); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public joinCriteria(): JoinCriteriaContext { let _localctx: JoinCriteriaContext = new JoinCriteriaContext(this._ctx, this.state); this.enterRule(_localctx, 198, SparkSqlParser.RULE_joinCriteria); try { this.state = 2552; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_ON: this.enterOuterAlt(_localctx, 1); { this.state = 2548; this.match(SparkSqlParser.KW_ON); this.state = 2549; this.booleanExpression(0); } break; case SparkSqlParser.KW_USING: this.enterOuterAlt(_localctx, 2); { this.state = 2550; this.match(SparkSqlParser.KW_USING); this.state = 2551; this.identifierList(); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public sample(): SampleContext { let _localctx: SampleContext = new SampleContext(this._ctx, this.state); this.enterRule(_localctx, 200, SparkSqlParser.RULE_sample); try { this.enterOuterAlt(_localctx, 1); { this.state = 2554; this.match(SparkSqlParser.KW_TABLESAMPLE); this.state = 2555; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2557; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 326, this._ctx) ) { case 1: { this.state = 2556; this.sampleMethod(); } break; } this.state = 2559; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2564; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 327, this._ctx) ) { case 1: { this.state = 2560; this.match(SparkSqlParser.KW_REPEATABLE); this.state = 2561; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2562; _localctx._seed = this.match(SparkSqlParser.INTEGER_VALUE); this.state = 2563; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public sampleMethod(): SampleMethodContext { let _localctx: SampleMethodContext = new SampleMethodContext(this._ctx, this.state); this.enterRule(_localctx, 202, SparkSqlParser.RULE_sampleMethod); let _la: number; try { this.state = 2590; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 331, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2567; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 2566; _localctx._negativeSign = this.match(SparkSqlParser.MINUS); } } this.state = 2569; _localctx._percentage = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.INTEGER_VALUE || _la === SparkSqlParser.DECIMAL_VALUE)) { _localctx._percentage = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 2570; this.match(SparkSqlParser.KW_PERCENTLIT); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2571; this.expression(); this.state = 2572; this.match(SparkSqlParser.KW_ROWS); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 2574; _localctx._sampleType = this.match(SparkSqlParser.KW_BUCKET); this.state = 2575; _localctx._numerator = this.match(SparkSqlParser.INTEGER_VALUE); this.state = 2576; this.match(SparkSqlParser.KW_OUT); this.state = 2577; this.match(SparkSqlParser.KW_OF); this.state = 2578; _localctx._denominator = this.match(SparkSqlParser.INTEGER_VALUE); this.state = 2587; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ON) { { this.state = 2579; this.match(SparkSqlParser.KW_ON); this.state = 2585; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 329, this._ctx) ) { case 1: { this.state = 2580; this.identifier(); } break; case 2: { this.state = 2581; this.qualifiedName(); this.state = 2582; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2583; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } } } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 2589; _localctx._bytes = this.expression(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public identifierList(): IdentifierListContext { let _localctx: IdentifierListContext = new IdentifierListContext(this._ctx, this.state); this.enterRule(_localctx, 204, SparkSqlParser.RULE_identifierList); try { this.enterOuterAlt(_localctx, 1); { this.state = 2592; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2593; this.identifierSeq(); this.state = 2594; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public identifierSeq(): IdentifierSeqContext { let _localctx: IdentifierSeqContext = new IdentifierSeqContext(this._ctx, this.state); this.enterRule(_localctx, 206, SparkSqlParser.RULE_identifierSeq); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 2596; _localctx._errorCapturingIdentifier = this.errorCapturingIdentifier(); _localctx._ident.push(_localctx._errorCapturingIdentifier); this.state = 2601; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 332, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2597; this.match(SparkSqlParser.COMMA); this.state = 2598; _localctx._errorCapturingIdentifier = this.errorCapturingIdentifier(); _localctx._ident.push(_localctx._errorCapturingIdentifier); } } } this.state = 2603; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 332, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public orderedIdentifierList(): OrderedIdentifierListContext { let _localctx: OrderedIdentifierListContext = new OrderedIdentifierListContext(this._ctx, this.state); this.enterRule(_localctx, 208, SparkSqlParser.RULE_orderedIdentifierList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2604; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2605; this.orderedIdentifier(); this.state = 2610; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2606; this.match(SparkSqlParser.COMMA); this.state = 2607; this.orderedIdentifier(); } } this.state = 2612; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2613; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public orderedIdentifier(): OrderedIdentifierContext { let _localctx: OrderedIdentifierContext = new OrderedIdentifierContext(this._ctx, this.state); this.enterRule(_localctx, 210, SparkSqlParser.RULE_orderedIdentifier); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2615; _localctx._ident = this.errorCapturingIdentifier(); this.state = 2617; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ASC || _la === SparkSqlParser.KW_DESC) { { this.state = 2616; _localctx._ordering = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ASC || _la === SparkSqlParser.KW_DESC)) { _localctx._ordering = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public identifierCommentList(): IdentifierCommentListContext { let _localctx: IdentifierCommentListContext = new IdentifierCommentListContext(this._ctx, this.state); this.enterRule(_localctx, 212, SparkSqlParser.RULE_identifierCommentList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2619; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2620; this.identifierComment(); this.state = 2625; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2621; this.match(SparkSqlParser.COMMA); this.state = 2622; this.identifierComment(); } } this.state = 2627; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2628; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public identifierComment(): IdentifierCommentContext { let _localctx: IdentifierCommentContext = new IdentifierCommentContext(this._ctx, this.state); this.enterRule(_localctx, 214, SparkSqlParser.RULE_identifierComment); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2630; this.identifier(); this.state = 2632; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_COMMENT) { { this.state = 2631; this.commentSpec(); } } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public relationPrimary(): RelationPrimaryContext { let _localctx: RelationPrimaryContext = new RelationPrimaryContext(this._ctx, this.state); this.enterRule(_localctx, 216, SparkSqlParser.RULE_relationPrimary); try { this.state = 2661; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 341, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2634; this.identifierReference(); this.state = 2636; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 337, this._ctx) ) { case 1: { this.state = 2635; this.temporalClause(); } break; } this.state = 2639; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 338, this._ctx) ) { case 1: { this.state = 2638; this.sample(); } break; } this.state = 2641; this.tableAlias(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2643; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2644; this.query(); this.state = 2645; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2647; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 339, this._ctx) ) { case 1: { this.state = 2646; this.sample(); } break; } this.state = 2649; this.tableAlias(); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 2651; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2652; this.relation(); this.state = 2653; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2655; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 340, this._ctx) ) { case 1: { this.state = 2654; this.sample(); } break; } this.state = 2657; this.tableAlias(); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 2659; this.inlineTable(); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 2660; this.functionTable(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public inlineTable(): InlineTableContext { let _localctx: InlineTableContext = new InlineTableContext(this._ctx, this.state); this.enterRule(_localctx, 218, SparkSqlParser.RULE_inlineTable); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 2663; this.match(SparkSqlParser.KW_VALUES); this.state = 2664; this.expression(); this.state = 2669; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 342, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2665; this.match(SparkSqlParser.COMMA); this.state = 2666; this.expression(); } } } this.state = 2671; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 342, this._ctx); } this.state = 2672; this.tableAlias(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public functionTableSubqueryArgument(): FunctionTableSubqueryArgumentContext { let _localctx: FunctionTableSubqueryArgumentContext = new FunctionTableSubqueryArgumentContext(this._ctx, this.state); this.enterRule(_localctx, 220, SparkSqlParser.RULE_functionTableSubqueryArgument); let _la: number; try { this.state = 2693; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 346, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2674; this.match(SparkSqlParser.KW_TABLE); this.state = 2675; this.tableName(); this.state = 2677; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_DISTRIBUTE || _la === SparkSqlParser.KW_PARTITION || _la === SparkSqlParser.KW_WITH) { { this.state = 2676; this.tableArgumentPartitioning(); } } } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2679; this.match(SparkSqlParser.KW_TABLE); this.state = 2680; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2681; this.tableName(); this.state = 2682; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2684; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_DISTRIBUTE || _la === SparkSqlParser.KW_PARTITION || _la === SparkSqlParser.KW_WITH) { { this.state = 2683; this.tableArgumentPartitioning(); } } } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 2686; this.match(SparkSqlParser.KW_TABLE); this.state = 2687; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2688; this.query(); this.state = 2689; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2691; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_DISTRIBUTE || _la === SparkSqlParser.KW_PARTITION || _la === SparkSqlParser.KW_WITH) { { this.state = 2690; this.tableArgumentPartitioning(); } } } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public tableArgumentPartitioning(): TableArgumentPartitioningContext { let _localctx: TableArgumentPartitioningContext = new TableArgumentPartitioningContext(this._ctx, this.state); this.enterRule(_localctx, 222, SparkSqlParser.RULE_tableArgumentPartitioning); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2714; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_WITH: { { this.state = 2695; this.match(SparkSqlParser.KW_WITH); this.state = 2696; this.match(SparkSqlParser.KW_SINGLE); this.state = 2697; this.match(SparkSqlParser.KW_PARTITION); } } break; case SparkSqlParser.KW_DISTRIBUTE: case SparkSqlParser.KW_PARTITION: { { this.state = 2698; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DISTRIBUTE || _la === SparkSqlParser.KW_PARTITION)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 2699; this.match(SparkSqlParser.KW_BY); this.state = 2712; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 348, this._ctx) ) { case 1: { { { this.state = 2700; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2701; _localctx._expression = this.expression(); _localctx._partition.push(_localctx._expression); this.state = 2706; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2702; this.match(SparkSqlParser.COMMA); this.state = 2703; _localctx._expression = this.expression(); _localctx._partition.push(_localctx._expression); } } this.state = 2708; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2709; this.match(SparkSqlParser.RIGHT_PAREN); } } } break; case 2: { this.state = 2711; _localctx._expression = this.expression(); _localctx._partition.push(_localctx._expression); } break; } } } break; default: throw new NoViableAltException(this); } this.state = 2732; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ORDER || _la === SparkSqlParser.KW_SORT) { { this.state = 2716; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ORDER || _la === SparkSqlParser.KW_SORT)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 2717; this.match(SparkSqlParser.KW_BY); { this.state = 2730; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 351, this._ctx) ) { case 1: { { this.state = 2718; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2719; this.sortItem(); this.state = 2724; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2720; this.match(SparkSqlParser.COMMA); this.state = 2721; this.sortItem(); } } this.state = 2726; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2727; this.match(SparkSqlParser.RIGHT_PAREN); } } break; case 2: { this.state = 2729; this.sortItem(); } break; } } } } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public functionTableNamedArgumentExpression(): FunctionTableNamedArgumentExpressionContext { let _localctx: FunctionTableNamedArgumentExpressionContext = new FunctionTableNamedArgumentExpressionContext(this._ctx, this.state); this.enterRule(_localctx, 224, SparkSqlParser.RULE_functionTableNamedArgumentExpression); try { this.enterOuterAlt(_localctx, 1); { this.state = 2734; _localctx._key = this.identifier(); this.state = 2735; this.match(SparkSqlParser.FAT_ARROW); this.state = 2736; _localctx._table = this.functionTableSubqueryArgument(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public functionTableReferenceArgument(): FunctionTableReferenceArgumentContext { let _localctx: FunctionTableReferenceArgumentContext = new FunctionTableReferenceArgumentContext(this._ctx, this.state); this.enterRule(_localctx, 226, SparkSqlParser.RULE_functionTableReferenceArgument); try { this.state = 2740; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 353, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2738; this.functionTableSubqueryArgument(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2739; this.functionTableNamedArgumentExpression(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public functionTableArgument(): FunctionTableArgumentContext { let _localctx: FunctionTableArgumentContext = new FunctionTableArgumentContext(this._ctx, this.state); this.enterRule(_localctx, 228, SparkSqlParser.RULE_functionTableArgument); try { this.state = 2744; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 354, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2742; this.functionTableReferenceArgument(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2743; this.functionArgument(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public functionTable(): FunctionTableContext { let _localctx: FunctionTableContext = new FunctionTableContext(this._ctx, this.state); this.enterRule(_localctx, 230, SparkSqlParser.RULE_functionTable); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2746; this.functionName(); this.state = 2747; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2756; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 356, this._ctx) ) { case 1: { this.state = 2748; this.functionTableArgument(); this.state = 2753; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2749; this.match(SparkSqlParser.COMMA); this.state = 2750; this.functionTableArgument(); } } this.state = 2755; this._errHandler.sync(this); _la = this._input.LA(1); } } break; } this.state = 2758; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 2759; this.tableAlias(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public tableAlias(): TableAliasContext { let _localctx: TableAliasContext = new TableAliasContext(this._ctx, this.state); this.enterRule(_localctx, 232, SparkSqlParser.RULE_tableAlias); try { this.enterOuterAlt(_localctx, 1); { this.state = 2768; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 359, this._ctx) ) { case 1: { this.state = 2762; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 357, this._ctx) ) { case 1: { this.state = 2761; this.match(SparkSqlParser.KW_AS); } break; } this.state = 2764; this.strictIdentifier(); this.state = 2766; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 358, this._ctx) ) { case 1: { this.state = 2765; this.identifierList(); } break; } } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public rowFormat(): RowFormatContext { let _localctx: RowFormatContext = new RowFormatContext(this._ctx, this.state); this.enterRule(_localctx, 234, SparkSqlParser.RULE_rowFormat); try { this.state = 2819; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 367, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2770; this.match(SparkSqlParser.KW_ROW); this.state = 2771; this.match(SparkSqlParser.KW_FORMAT); this.state = 2772; this.match(SparkSqlParser.KW_SERDE); this.state = 2773; _localctx._name = this.stringLit(); this.state = 2777; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 360, this._ctx) ) { case 1: { this.state = 2774; this.match(SparkSqlParser.KW_WITH); this.state = 2775; this.match(SparkSqlParser.KW_SERDEPROPERTIES); this.state = 2776; _localctx._props = this.propertyList(); } break; } } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2779; this.match(SparkSqlParser.KW_ROW); this.state = 2780; this.match(SparkSqlParser.KW_FORMAT); this.state = 2781; this.match(SparkSqlParser.KW_DELIMITED); this.state = 2791; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 362, this._ctx) ) { case 1: { this.state = 2782; this.match(SparkSqlParser.KW_FIELDS); this.state = 2783; this.match(SparkSqlParser.KW_TERMINATED); this.state = 2784; this.match(SparkSqlParser.KW_BY); this.state = 2785; _localctx._fieldsTerminatedBy = this.stringLit(); this.state = 2789; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 361, this._ctx) ) { case 1: { this.state = 2786; this.match(SparkSqlParser.KW_ESCAPED); this.state = 2787; this.match(SparkSqlParser.KW_BY); this.state = 2788; _localctx._escapedBy = this.stringLit(); } break; } } break; } this.state = 2798; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 363, this._ctx) ) { case 1: { this.state = 2793; this.match(SparkSqlParser.KW_COLLECTION); this.state = 2794; this.match(SparkSqlParser.KW_ITEMS); this.state = 2795; this.match(SparkSqlParser.KW_TERMINATED); this.state = 2796; this.match(SparkSqlParser.KW_BY); this.state = 2797; _localctx._collectionItemsTerminatedBy = this.stringLit(); } break; } this.state = 2805; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 364, this._ctx) ) { case 1: { this.state = 2800; this.match(SparkSqlParser.KW_MAP); this.state = 2801; this.match(SparkSqlParser.KW_KEYS); this.state = 2802; this.match(SparkSqlParser.KW_TERMINATED); this.state = 2803; this.match(SparkSqlParser.KW_BY); this.state = 2804; _localctx._keysTerminatedBy = this.stringLit(); } break; } this.state = 2811; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 365, this._ctx) ) { case 1: { this.state = 2807; this.match(SparkSqlParser.KW_LINES); this.state = 2808; this.match(SparkSqlParser.KW_TERMINATED); this.state = 2809; this.match(SparkSqlParser.KW_BY); this.state = 2810; _localctx._linesSeparatedBy = this.stringLit(); } break; } this.state = 2817; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 366, this._ctx) ) { case 1: { this.state = 2813; this.match(SparkSqlParser.KW_NULL); this.state = 2814; this.match(SparkSqlParser.KW_DEFINED); this.state = 2815; this.match(SparkSqlParser.KW_AS); this.state = 2816; _localctx._nullDefinedAs = this.stringLit(); } break; } } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public multipartIdentifierList(): MultipartIdentifierListContext { let _localctx: MultipartIdentifierListContext = new MultipartIdentifierListContext(this._ctx, this.state); this.enterRule(_localctx, 236, SparkSqlParser.RULE_multipartIdentifierList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2821; this.multipartIdentifier(); this.state = 2826; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2822; this.match(SparkSqlParser.COMMA); this.state = 2823; this.multipartIdentifier(); } } this.state = 2828; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public multipartIdentifier(): MultipartIdentifierContext { let _localctx: MultipartIdentifierContext = new MultipartIdentifierContext(this._ctx, this.state); this.enterRule(_localctx, 238, SparkSqlParser.RULE_multipartIdentifier); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 2829; _localctx._errorCapturingIdentifier = this.errorCapturingIdentifier(); _localctx._parts.push(_localctx._errorCapturingIdentifier); this.state = 2834; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 369, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2830; this.match(SparkSqlParser.DOT); this.state = 2831; _localctx._errorCapturingIdentifier = this.errorCapturingIdentifier(); _localctx._parts.push(_localctx._errorCapturingIdentifier); } } } this.state = 2836; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 369, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public multipartIdentifierPropertyList(): MultipartIdentifierPropertyListContext { let _localctx: MultipartIdentifierPropertyListContext = new MultipartIdentifierPropertyListContext(this._ctx, this.state); this.enterRule(_localctx, 240, SparkSqlParser.RULE_multipartIdentifierPropertyList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2837; this.multipartIdentifierProperty(); this.state = 2842; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2838; this.match(SparkSqlParser.COMMA); this.state = 2839; this.multipartIdentifierProperty(); } } this.state = 2844; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public multipartIdentifierProperty(): MultipartIdentifierPropertyContext { let _localctx: MultipartIdentifierPropertyContext = new MultipartIdentifierPropertyContext(this._ctx, this.state); this.enterRule(_localctx, 242, SparkSqlParser.RULE_multipartIdentifierProperty); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2845; this.multipartIdentifier(); this.state = 2848; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_OPTIONS) { { this.state = 2846; this.match(SparkSqlParser.KW_OPTIONS); this.state = 2847; _localctx._options = this.propertyList(); } } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public tableIdentifier(): TableIdentifierContext { let _localctx: TableIdentifierContext = new TableIdentifierContext(this._ctx, this.state); this.enterRule(_localctx, 244, SparkSqlParser.RULE_tableIdentifier); try { this.enterOuterAlt(_localctx, 1); { this.state = 2853; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 372, this._ctx) ) { case 1: { this.state = 2850; _localctx._db = this.errorCapturingIdentifier(); this.state = 2851; this.match(SparkSqlParser.DOT); } break; } this.state = 2855; _localctx._table = this.errorCapturingIdentifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public viewIdentifier(): ViewIdentifierContext { let _localctx: ViewIdentifierContext = new ViewIdentifierContext(this._ctx, this.state); this.enterRule(_localctx, 246, SparkSqlParser.RULE_viewIdentifier); try { this.enterOuterAlt(_localctx, 1); { this.state = 2860; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 373, this._ctx) ) { case 1: { this.state = 2857; _localctx._db = this.errorCapturingIdentifier(); this.state = 2858; this.match(SparkSqlParser.DOT); } break; } this.state = 2862; _localctx._view = this.errorCapturingIdentifier(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public namedExpression(): NamedExpressionContext { let _localctx: NamedExpressionContext = new NamedExpressionContext(this._ctx, this.state); this.enterRule(_localctx, 248, SparkSqlParser.RULE_namedExpression); try { this.enterOuterAlt(_localctx, 1); { this.state = 2864; this.expression(); this.state = 2872; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 376, this._ctx) ) { case 1: { this.state = 2866; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 374, this._ctx) ) { case 1: { this.state = 2865; this.match(SparkSqlParser.KW_AS); } break; } this.state = 2870; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 375, this._ctx) ) { case 1: { this.state = 2868; _localctx._name = this.errorCapturingIdentifier(); } break; case 2: { this.state = 2869; this.identifierList(); } break; } } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public namedExpressionSeq(): NamedExpressionSeqContext { let _localctx: NamedExpressionSeqContext = new NamedExpressionSeqContext(this._ctx, this.state); this.enterRule(_localctx, 250, SparkSqlParser.RULE_namedExpressionSeq); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 2874; this.namedExpression(); this.state = 2879; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 377, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 2875; this.match(SparkSqlParser.COMMA); this.state = 2876; this.namedExpression(); } } } this.state = 2881; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 377, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public partitionFieldList(): PartitionFieldListContext { let _localctx: PartitionFieldListContext = new PartitionFieldListContext(this._ctx, this.state); this.enterRule(_localctx, 252, SparkSqlParser.RULE_partitionFieldList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2882; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2883; _localctx._partitionField = this.partitionField(); _localctx._fields.push(_localctx._partitionField); this.state = 2888; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2884; this.match(SparkSqlParser.COMMA); this.state = 2885; _localctx._partitionField = this.partitionField(); _localctx._fields.push(_localctx._partitionField); } } this.state = 2890; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2891; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public partitionField(): PartitionFieldContext { let _localctx: PartitionFieldContext = new PartitionFieldContext(this._ctx, this.state); this.enterRule(_localctx, 254, SparkSqlParser.RULE_partitionField); try { this.state = 2895; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 379, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2893; this.transform(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2894; this.colType(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public transform(): TransformContext { let _localctx: TransformContext = new TransformContext(this._ctx, this.state); this.enterRule(_localctx, 256, SparkSqlParser.RULE_transform); let _la: number; try { this.state = 2910; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 381, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2897; this.qualifiedName(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2898; _localctx._transformName = this.identifier(); this.state = 2899; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2900; this.transformArgument(); this.state = 2905; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2901; this.match(SparkSqlParser.COMMA); this.state = 2902; this.transformArgument(); } } this.state = 2907; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2908; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public transformArgument(): TransformArgumentContext { let _localctx: TransformArgumentContext = new TransformArgumentContext(this._ctx, this.state); this.enterRule(_localctx, 258, SparkSqlParser.RULE_transformArgument); try { this.state = 2914; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 382, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2912; this.qualifiedName(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2913; this.constant(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public expression(): ExpressionContext { let _localctx: ExpressionContext = new ExpressionContext(this._ctx, this.state); this.enterRule(_localctx, 260, SparkSqlParser.RULE_expression); try { this.enterOuterAlt(_localctx, 1); { this.state = 2916; this.booleanExpression(0); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public namedArgumentExpression(): NamedArgumentExpressionContext { let _localctx: NamedArgumentExpressionContext = new NamedArgumentExpressionContext(this._ctx, this.state); this.enterRule(_localctx, 262, SparkSqlParser.RULE_namedArgumentExpression); try { this.enterOuterAlt(_localctx, 1); { this.state = 2918; _localctx._key = this.identifier(); this.state = 2919; this.match(SparkSqlParser.FAT_ARROW); this.state = 2920; _localctx._value = this.expression(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public functionArgument(): FunctionArgumentContext { let _localctx: FunctionArgumentContext = new FunctionArgumentContext(this._ctx, this.state); this.enterRule(_localctx, 264, SparkSqlParser.RULE_functionArgument); try { this.state = 2924; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 383, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2922; this.expression(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2923; this.namedArgumentExpression(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public expressionSeq(): ExpressionSeqContext { let _localctx: ExpressionSeqContext = new ExpressionSeqContext(this._ctx, this.state); this.enterRule(_localctx, 266, SparkSqlParser.RULE_expressionSeq); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 2926; this.expression(); this.state = 2931; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2927; this.match(SparkSqlParser.COMMA); this.state = 2928; this.expression(); } } this.state = 2933; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } public booleanExpression(): BooleanExpressionContext; public booleanExpression(_p: number): BooleanExpressionContext; // @RuleVersion(0) public booleanExpression(_p?: number): BooleanExpressionContext { if (_p === undefined) { _p = 0; } let _parentctx: ParserRuleContext = this._ctx; let _parentState: number = this.state; let _localctx: BooleanExpressionContext = new BooleanExpressionContext(this._ctx, _parentState); let _prevctx: BooleanExpressionContext = _localctx; let _startState: number = 268; this.enterRecursionRule(_localctx, 268, SparkSqlParser.RULE_booleanExpression, _p); let _la: number; try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 2946; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 386, this._ctx) ) { case 1: { this.state = 2935; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_NOT || _la === SparkSqlParser.NOT)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 2936; this.booleanExpression(5); } break; case 2: { this.state = 2937; this.match(SparkSqlParser.KW_EXISTS); this.state = 2938; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2939; this.query(); this.state = 2940; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 3: { this.state = 2942; this.valueExpression(0); this.state = 2944; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 385, this._ctx) ) { case 1: { this.state = 2943; this.predicate(); } break; } } break; } this._ctx._stop = this._input.tryLT(-1); this.state = 2956; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 388, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { if (this._parseListeners != null) { this.triggerExitRuleEvent(); } _prevctx = _localctx; { this.state = 2954; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 387, this._ctx) ) { case 1: { _localctx = new BooleanExpressionContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_booleanExpression); this.state = 2948; if (!(this.precpred(this._ctx, 2))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 2)"); } this.state = 2949; _localctx._operator = this.match(SparkSqlParser.KW_AND); this.state = 2950; _localctx._right = this.booleanExpression(3); } break; case 2: { _localctx = new BooleanExpressionContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_booleanExpression); this.state = 2951; if (!(this.precpred(this._ctx, 1))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 1)"); } this.state = 2952; _localctx._operator = this.match(SparkSqlParser.KW_OR); this.state = 2953; _localctx._right = this.booleanExpression(2); } break; } } } this.state = 2958; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 388, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.unrollRecursionContexts(_parentctx); } return _localctx; } // @RuleVersion(0) public predicate(): PredicateContext { let _localctx: PredicateContext = new PredicateContext(this._ctx, this.state); this.enterRule(_localctx, 270, SparkSqlParser.RULE_predicate); let _la: number; try { this.state = 3041; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 402, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 2960; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_NOT) { { this.state = 2959; this.match(SparkSqlParser.KW_NOT); } } this.state = 2962; _localctx._kind = this.match(SparkSqlParser.KW_BETWEEN); this.state = 2963; _localctx._lower = this.valueExpression(0); this.state = 2964; this.match(SparkSqlParser.KW_AND); this.state = 2965; _localctx._upper = this.valueExpression(0); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 2968; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_NOT) { { this.state = 2967; this.match(SparkSqlParser.KW_NOT); } } this.state = 2970; _localctx._kind = this.match(SparkSqlParser.KW_IN); this.state = 2971; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2972; this.expression(); this.state = 2977; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 2973; this.match(SparkSqlParser.COMMA); this.state = 2974; this.expression(); } } this.state = 2979; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 2980; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 2983; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_NOT) { { this.state = 2982; this.match(SparkSqlParser.KW_NOT); } } this.state = 2985; _localctx._kind = this.match(SparkSqlParser.KW_IN); this.state = 2986; this.match(SparkSqlParser.LEFT_PAREN); this.state = 2987; this.query(); this.state = 2988; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 2991; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_NOT) { { this.state = 2990; this.match(SparkSqlParser.KW_NOT); } } this.state = 2993; _localctx._kind = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_RLIKE || _la === SparkSqlParser.KW_REGEXP)) { _localctx._kind = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 2994; _localctx._pattern = this.valueExpression(0); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 2996; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_NOT) { { this.state = 2995; this.match(SparkSqlParser.KW_NOT); } } this.state = 2998; _localctx._kind = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_LIKE || _la === SparkSqlParser.KW_ILIKE)) { _localctx._kind = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 2999; _localctx._quantifier = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ALL || _la === SparkSqlParser.KW_ANY || _la === SparkSqlParser.KW_SOME)) { _localctx._quantifier = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3013; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 396, this._ctx) ) { case 1: { this.state = 3000; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3001; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 2: { this.state = 3002; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3003; this.expression(); this.state = 3008; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3004; this.match(SparkSqlParser.COMMA); this.state = 3005; this.expression(); } } this.state = 3010; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 3011; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } break; case 6: this.enterOuterAlt(_localctx, 6); { this.state = 3016; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_NOT) { { this.state = 3015; this.match(SparkSqlParser.KW_NOT); } } this.state = 3018; _localctx._kind = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_LIKE || _la === SparkSqlParser.KW_ILIKE)) { _localctx._kind = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3019; _localctx._pattern = this.valueExpression(0); this.state = 3022; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 398, this._ctx) ) { case 1: { this.state = 3020; this.match(SparkSqlParser.KW_ESCAPE); this.state = 3021; _localctx._escapeChar = this.stringLit(); } break; } } break; case 7: this.enterOuterAlt(_localctx, 7); { this.state = 3024; this.match(SparkSqlParser.KW_IS); this.state = 3026; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_NOT) { { this.state = 3025; this.match(SparkSqlParser.KW_NOT); } } this.state = 3028; _localctx._kind = this.match(SparkSqlParser.KW_NULL); } break; case 8: this.enterOuterAlt(_localctx, 8); { this.state = 3029; this.match(SparkSqlParser.KW_IS); this.state = 3031; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_NOT) { { this.state = 3030; this.match(SparkSqlParser.KW_NOT); } } this.state = 3033; _localctx._kind = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FALSE || _la === SparkSqlParser.KW_TRUE || _la === SparkSqlParser.KW_UNKNOWN)) { _localctx._kind = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; case 9: this.enterOuterAlt(_localctx, 9); { this.state = 3034; this.match(SparkSqlParser.KW_IS); this.state = 3036; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_NOT) { { this.state = 3035; this.match(SparkSqlParser.KW_NOT); } } this.state = 3038; _localctx._kind = this.match(SparkSqlParser.KW_DISTINCT); this.state = 3039; this.match(SparkSqlParser.KW_FROM); this.state = 3040; _localctx._right = this.valueExpression(0); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } public valueExpression(): ValueExpressionContext; public valueExpression(_p: number): ValueExpressionContext; // @RuleVersion(0) public valueExpression(_p?: number): ValueExpressionContext { if (_p === undefined) { _p = 0; } let _parentctx: ParserRuleContext = this._ctx; let _parentState: number = this.state; let _localctx: ValueExpressionContext = new ValueExpressionContext(this._ctx, _parentState); let _prevctx: ValueExpressionContext = _localctx; let _startState: number = 272; this.enterRecursionRule(_localctx, 272, SparkSqlParser.RULE_valueExpression, _p); let _la: number; try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 3047; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 403, this._ctx) ) { case 1: { this.state = 3044; this.primaryExpression(0); } break; case 2: { this.state = 3045; _localctx._operator = this._input.LT(1); _la = this._input.LA(1); if (!(((((_la - 353)) & ~0x1F) === 0 && ((1 << (_la - 353)) & ((1 << (SparkSqlParser.PLUS - 353)) | (1 << (SparkSqlParser.MINUS - 353)) | (1 << (SparkSqlParser.TILDE - 353)))) !== 0))) { _localctx._operator = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3046; this.valueExpression(7); } break; } this._ctx._stop = this._input.tryLT(-1); this.state = 3070; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 405, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { if (this._parseListeners != null) { this.triggerExitRuleEvent(); } _prevctx = _localctx; { this.state = 3068; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 404, this._ctx) ) { case 1: { _localctx = new ValueExpressionContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_valueExpression); this.state = 3049; if (!(this.precpred(this._ctx, 6))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 6)"); } this.state = 3050; _localctx._operator = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DIV || ((((_la - 355)) & ~0x1F) === 0 && ((1 << (_la - 355)) & ((1 << (SparkSqlParser.ASTERISK - 355)) | (1 << (SparkSqlParser.SLASH - 355)) | (1 << (SparkSqlParser.PERCENT - 355)))) !== 0))) { _localctx._operator = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3051; _localctx._right = this.valueExpression(7); } break; case 2: { _localctx = new ValueExpressionContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_valueExpression); this.state = 3052; if (!(this.precpred(this._ctx, 5))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 5)"); } this.state = 3053; _localctx._operator = this._input.LT(1); _la = this._input.LA(1); if (!(((((_la - 353)) & ~0x1F) === 0 && ((1 << (_la - 353)) & ((1 << (SparkSqlParser.PLUS - 353)) | (1 << (SparkSqlParser.MINUS - 353)) | (1 << (SparkSqlParser.CONCAT_PIPE - 353)))) !== 0))) { _localctx._operator = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3054; _localctx._right = this.valueExpression(6); } break; case 3: { _localctx = new ValueExpressionContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_valueExpression); this.state = 3055; if (!(this.precpred(this._ctx, 4))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 4)"); } this.state = 3056; _localctx._operator = this.match(SparkSqlParser.AMPERSAND); this.state = 3057; _localctx._right = this.valueExpression(5); } break; case 4: { _localctx = new ValueExpressionContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_valueExpression); this.state = 3058; if (!(this.precpred(this._ctx, 3))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 3)"); } this.state = 3059; _localctx._operator = this.match(SparkSqlParser.HAT); this.state = 3060; _localctx._right = this.valueExpression(4); } break; case 5: { _localctx = new ValueExpressionContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_valueExpression); this.state = 3061; if (!(this.precpred(this._ctx, 2))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 2)"); } this.state = 3062; _localctx._operator = this.match(SparkSqlParser.PIPE); this.state = 3063; _localctx._right = this.valueExpression(3); } break; case 6: { _localctx = new ValueExpressionContext(_parentctx, _parentState); _localctx._left = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_valueExpression); this.state = 3064; if (!(this.precpred(this._ctx, 1))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 1)"); } this.state = 3065; this.comparisonOperator(); this.state = 3066; _localctx._right = this.valueExpression(2); } break; } } } this.state = 3072; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 405, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.unrollRecursionContexts(_parentctx); } return _localctx; } // @RuleVersion(0) public datetimeUnit(): DatetimeUnitContext { let _localctx: DatetimeUnitContext = new DatetimeUnitContext(this._ctx, this.state); this.enterRule(_localctx, 274, SparkSqlParser.RULE_datetimeUnit); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3073; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DAY || _la === SparkSqlParser.KW_DAYOFYEAR || _la === SparkSqlParser.KW_HOUR || ((((_la - 176)) & ~0x1F) === 0 && ((1 << (_la - 176)) & ((1 << (SparkSqlParser.KW_MICROSECOND - 176)) | (1 << (SparkSqlParser.KW_MILLISECOND - 176)) | (1 << (SparkSqlParser.KW_MINUTE - 176)) | (1 << (SparkSqlParser.KW_MONTH - 176)))) !== 0) || _la === SparkSqlParser.KW_QUARTER || _la === SparkSqlParser.KW_SECOND || _la === SparkSqlParser.KW_WEEK || _la === SparkSqlParser.KW_YEAR)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } public primaryExpression(): PrimaryExpressionContext; public primaryExpression(_p: number): PrimaryExpressionContext; // @RuleVersion(0) public primaryExpression(_p?: number): PrimaryExpressionContext { if (_p === undefined) { _p = 0; } let _parentctx: ParserRuleContext = this._ctx; let _parentState: number = this.state; let _localctx: PrimaryExpressionContext = new PrimaryExpressionContext(this._ctx, _parentState); let _prevctx: PrimaryExpressionContext = _localctx; let _startState: number = 276; this.enterRecursionRule(_localctx, 276, SparkSqlParser.RULE_primaryExpression, _p); let _la: number; try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 3324; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 431, this._ctx) ) { case 1: { this.state = 3076; _localctx._name = this._input.LT(1); _la = this._input.LA(1); if (!(((((_la - 63)) & ~0x1F) === 0 && ((1 << (_la - 63)) & ((1 << (SparkSqlParser.KW_CURRENT_DATE - 63)) | (1 << (SparkSqlParser.KW_CURRENT_TIMESTAMP - 63)) | (1 << (SparkSqlParser.KW_CURRENT_USER - 63)))) !== 0) || _la === SparkSqlParser.KW_SESSION_USER || _la === SparkSqlParser.KW_USER)) { _localctx._name = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; case 2: { this.state = 3077; _localctx._name = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DATEADD || _la === SparkSqlParser.KW_DATE_ADD || _la === SparkSqlParser.KW_TIMESTAMPADD)) { _localctx._name = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3078; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3081; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 406, this._ctx) ) { case 1: { this.state = 3079; _localctx._unit = this.datetimeUnit(); } break; case 2: { this.state = 3080; _localctx._invalidUnit = this.stringLit(); } break; } this.state = 3083; this.match(SparkSqlParser.COMMA); this.state = 3084; _localctx._unitsAmount = this.valueExpression(0); this.state = 3085; this.match(SparkSqlParser.COMMA); this.state = 3086; _localctx._timestamp = this.valueExpression(0); this.state = 3087; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 3: { this.state = 3089; _localctx._name = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DATEDIFF || _la === SparkSqlParser.KW_DATE_DIFF || _la === SparkSqlParser.KW_TIMEDIFF || _la === SparkSqlParser.KW_TIMESTAMPDIFF)) { _localctx._name = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3090; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3093; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 407, this._ctx) ) { case 1: { this.state = 3091; _localctx._unit = this.datetimeUnit(); } break; case 2: { this.state = 3092; _localctx._invalidUnit = this.stringLit(); } break; } this.state = 3095; this.match(SparkSqlParser.COMMA); this.state = 3096; _localctx._startTimestamp = this.valueExpression(0); this.state = 3097; this.match(SparkSqlParser.COMMA); this.state = 3098; _localctx._endTimestamp = this.valueExpression(0); this.state = 3099; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 4: { this.state = 3101; this.match(SparkSqlParser.KW_CASE); this.state = 3103; this._errHandler.sync(this); _la = this._input.LA(1); do { { { this.state = 3102; this.whenClause(); } } this.state = 3105; this._errHandler.sync(this); _la = this._input.LA(1); } while (_la === SparkSqlParser.KW_WHEN); this.state = 3109; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ELSE) { { this.state = 3107; this.match(SparkSqlParser.KW_ELSE); this.state = 3108; _localctx._elseExpression = this.expression(); } } this.state = 3111; this.match(SparkSqlParser.KW_END); } break; case 5: { this.state = 3113; this.match(SparkSqlParser.KW_CASE); this.state = 3114; this.expression(); this.state = 3116; this._errHandler.sync(this); _la = this._input.LA(1); do { { { this.state = 3115; this.whenClause(); } } this.state = 3118; this._errHandler.sync(this); _la = this._input.LA(1); } while (_la === SparkSqlParser.KW_WHEN); this.state = 3122; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ELSE) { { this.state = 3120; this.match(SparkSqlParser.KW_ELSE); this.state = 3121; _localctx._elseExpression = this.expression(); } } this.state = 3124; this.match(SparkSqlParser.KW_END); } break; case 6: { this.state = 3126; _localctx._name = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_CAST || _la === SparkSqlParser.KW_TRY_CAST)) { _localctx._name = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3127; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3128; this.expression(); this.state = 3129; this.match(SparkSqlParser.KW_AS); this.state = 3130; this.dataType(); this.state = 3131; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 7: { this.state = 3133; this.match(SparkSqlParser.KW_STRUCT); this.state = 3134; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3143; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 413, this._ctx) ) { case 1: { this.state = 3135; this.namedExpression(); this.state = 3140; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3136; this.match(SparkSqlParser.COMMA); this.state = 3137; this.namedExpression(); } } this.state = 3142; this._errHandler.sync(this); _la = this._input.LA(1); } } break; } this.state = 3145; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 8: { this.state = 3146; this.match(SparkSqlParser.KW_FIRST); this.state = 3147; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3148; this.expression(); this.state = 3151; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_IGNORE) { { this.state = 3149; this.match(SparkSqlParser.KW_IGNORE); this.state = 3150; this.match(SparkSqlParser.KW_NULLS); } } this.state = 3153; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 9: { this.state = 3155; this.match(SparkSqlParser.KW_ANY_VALUE); this.state = 3156; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3157; this.expression(); this.state = 3160; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_IGNORE) { { this.state = 3158; this.match(SparkSqlParser.KW_IGNORE); this.state = 3159; this.match(SparkSqlParser.KW_NULLS); } } this.state = 3162; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 10: { this.state = 3164; this.match(SparkSqlParser.KW_LAST); this.state = 3165; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3166; this.expression(); this.state = 3169; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_IGNORE) { { this.state = 3167; this.match(SparkSqlParser.KW_IGNORE); this.state = 3168; this.match(SparkSqlParser.KW_NULLS); } } this.state = 3171; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 11: { this.state = 3173; this.match(SparkSqlParser.KW_POSITION); this.state = 3174; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3175; _localctx._substr = this.valueExpression(0); this.state = 3176; this.match(SparkSqlParser.KW_IN); this.state = 3177; _localctx._str = this.valueExpression(0); this.state = 3178; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 12: { this.state = 3180; this.constant(); } break; case 13: { this.state = 3181; this.match(SparkSqlParser.ASTERISK); } break; case 14: { this.state = 3182; this.qualifiedName(); this.state = 3183; this.match(SparkSqlParser.DOT); this.state = 3184; this.match(SparkSqlParser.ASTERISK); } break; case 15: { this.state = 3186; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3187; this.namedExpression(); this.state = 3190; this._errHandler.sync(this); _la = this._input.LA(1); do { { { this.state = 3188; this.match(SparkSqlParser.COMMA); this.state = 3189; this.namedExpression(); } } this.state = 3192; this._errHandler.sync(this); _la = this._input.LA(1); } while (_la === SparkSqlParser.COMMA); this.state = 3194; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 16: { this.state = 3196; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3197; this.query(); this.state = 3198; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 17: { this.state = 3200; this.match(SparkSqlParser.KW_IDENTIFIER_KW); this.state = 3201; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3202; this.expression(); this.state = 3203; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 18: { this.state = 3205; this.functionName(); this.state = 3206; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3218; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 420, this._ctx) ) { case 1: { this.state = 3208; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 418, this._ctx) ) { case 1: { this.state = 3207; this.setQuantifier(); } break; } this.state = 3210; this.functionArgument(); this.state = 3215; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3211; this.match(SparkSqlParser.COMMA); this.state = 3212; this.functionArgument(); } } this.state = 3217; this._errHandler.sync(this); _la = this._input.LA(1); } } break; } this.state = 3220; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 3227; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 421, this._ctx) ) { case 1: { this.state = 3221; this.match(SparkSqlParser.KW_FILTER); this.state = 3222; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3223; this.match(SparkSqlParser.KW_WHERE); this.state = 3224; _localctx._where = this.booleanExpression(0); this.state = 3225; this.match(SparkSqlParser.RIGHT_PAREN); } break; } this.state = 3231; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 422, this._ctx) ) { case 1: { this.state = 3229; _localctx._nullsOption = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_IGNORE || _la === SparkSqlParser.KW_RESPECT)) { _localctx._nullsOption = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3230; this.match(SparkSqlParser.KW_NULLS); } break; } this.state = 3235; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 423, this._ctx) ) { case 1: { this.state = 3233; this.match(SparkSqlParser.KW_OVER); this.state = 3234; this.windowSpec(); } break; } } break; case 19: { this.state = 3237; this.identifier(); this.state = 3238; this.match(SparkSqlParser.ARROW); this.state = 3239; this.expression(); } break; case 20: { this.state = 3241; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3242; this.identifier(); this.state = 3245; this._errHandler.sync(this); _la = this._input.LA(1); do { { { this.state = 3243; this.match(SparkSqlParser.COMMA); this.state = 3244; this.identifier(); } } this.state = 3247; this._errHandler.sync(this); _la = this._input.LA(1); } while (_la === SparkSqlParser.COMMA); this.state = 3249; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 3250; this.match(SparkSqlParser.ARROW); this.state = 3251; this.expression(); } break; case 21: { this.state = 3253; this.identifier(); } break; case 22: { this.state = 3254; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3255; this.expression(); this.state = 3256; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 23: { this.state = 3258; this.match(SparkSqlParser.KW_EXTRACT); this.state = 3259; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3260; _localctx._field = this.identifier(); this.state = 3261; this.match(SparkSqlParser.KW_FROM); this.state = 3262; _localctx._source = this.valueExpression(0); this.state = 3263; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 24: { this.state = 3265; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_SUBSTR || _la === SparkSqlParser.KW_SUBSTRING)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3266; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3267; _localctx._str = this.valueExpression(0); this.state = 3268; _la = this._input.LA(1); if (!(_la === SparkSqlParser.COMMA || _la === SparkSqlParser.KW_FROM)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3269; _localctx._pos = this.valueExpression(0); this.state = 3272; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.COMMA || _la === SparkSqlParser.KW_FOR) { { this.state = 3270; _la = this._input.LA(1); if (!(_la === SparkSqlParser.COMMA || _la === SparkSqlParser.KW_FOR)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3271; _localctx._len = this.valueExpression(0); } } this.state = 3274; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 25: { this.state = 3276; this.match(SparkSqlParser.KW_TRIM); this.state = 3277; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3279; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 426, this._ctx) ) { case 1: { this.state = 3278; _localctx._trimOption = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_BOTH || _la === SparkSqlParser.KW_LEADING || _la === SparkSqlParser.KW_TRAILING)) { _localctx._trimOption = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; } this.state = 3282; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 427, this._ctx) ) { case 1: { this.state = 3281; _localctx._trimStr = this.valueExpression(0); } break; } this.state = 3284; this.match(SparkSqlParser.KW_FROM); this.state = 3285; _localctx._srcStr = this.valueExpression(0); this.state = 3286; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 26: { this.state = 3288; this.match(SparkSqlParser.KW_OVERLAY); this.state = 3289; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3290; _localctx._input = this.valueExpression(0); this.state = 3291; this.match(SparkSqlParser.KW_PLACING); this.state = 3292; _localctx._replace = this.valueExpression(0); this.state = 3293; this.match(SparkSqlParser.KW_FROM); this.state = 3294; _localctx._position = this.valueExpression(0); this.state = 3297; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_FOR) { { this.state = 3295; this.match(SparkSqlParser.KW_FOR); this.state = 3296; _localctx._length = this.valueExpression(0); } } this.state = 3299; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 27: { this.state = 3301; _localctx._name = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_PERCENTILE_CONT || _la === SparkSqlParser.KW_PERCENTILE_DISC)) { _localctx._name = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3302; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3303; _localctx._percentage = this.valueExpression(0); this.state = 3304; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 3305; this.match(SparkSqlParser.KW_WITHIN); this.state = 3306; this.match(SparkSqlParser.KW_GROUP); this.state = 3307; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3308; this.match(SparkSqlParser.KW_ORDER); this.state = 3309; this.match(SparkSqlParser.KW_BY); this.state = 3310; this.sortItem(); this.state = 3311; this.match(SparkSqlParser.RIGHT_PAREN); this.state = 3318; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 429, this._ctx) ) { case 1: { this.state = 3312; this.match(SparkSqlParser.KW_FILTER); this.state = 3313; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3314; this.match(SparkSqlParser.KW_WHERE); this.state = 3315; _localctx._where = this.booleanExpression(0); this.state = 3316; this.match(SparkSqlParser.RIGHT_PAREN); } break; } this.state = 3322; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 430, this._ctx) ) { case 1: { this.state = 3320; this.match(SparkSqlParser.KW_OVER); this.state = 3321; this.windowSpec(); } break; } } break; } this._ctx._stop = this._input.tryLT(-1); this.state = 3336; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 433, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { if (this._parseListeners != null) { this.triggerExitRuleEvent(); } _prevctx = _localctx; { this.state = 3334; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 432, this._ctx) ) { case 1: { _localctx = new PrimaryExpressionContext(_parentctx, _parentState); _localctx._value = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_primaryExpression); this.state = 3326; if (!(this.precpred(this._ctx, 9))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 9)"); } this.state = 3327; this.match(SparkSqlParser.LEFT_BRACKET); this.state = 3328; _localctx._index = this.valueExpression(0); this.state = 3329; this.match(SparkSqlParser.RIGHT_BRACKET); } break; case 2: { _localctx = new PrimaryExpressionContext(_parentctx, _parentState); _localctx._base = _prevctx; this.pushNewRecursionContext(_localctx, _startState, SparkSqlParser.RULE_primaryExpression); this.state = 3331; if (!(this.precpred(this._ctx, 7))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 7)"); } this.state = 3332; this.match(SparkSqlParser.DOT); this.state = 3333; _localctx._fieldName = this.identifier(); } break; } } } this.state = 3338; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 433, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.unrollRecursionContexts(_parentctx); } return _localctx; } // @RuleVersion(0) public literalType(): LiteralTypeContext { let _localctx: LiteralTypeContext = new LiteralTypeContext(this._ctx, this.state); this.enterRule(_localctx, 278, SparkSqlParser.RULE_literalType); try { this.state = 3346; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 434, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3339; this.match(SparkSqlParser.KW_DATE); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3340; this.match(SparkSqlParser.KW_TIMESTAMP); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3341; this.match(SparkSqlParser.KW_TIMESTAMP_LTZ); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 3342; this.match(SparkSqlParser.KW_TIMESTAMP_NTZ); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 3343; this.match(SparkSqlParser.KW_INTERVAL); } break; case 6: this.enterOuterAlt(_localctx, 6); { this.state = 3344; this.match(SparkSqlParser.KW_BINARY_HEX); } break; case 7: this.enterOuterAlt(_localctx, 7); { this.state = 3345; _localctx._unsupportedType = this.identifier(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public constant(): ConstantContext { let _localctx: ConstantContext = new ConstantContext(this._ctx, this.state); this.enterRule(_localctx, 280, SparkSqlParser.RULE_constant); try { let _alt: number; this.state = 3363; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 436, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3348; this.match(SparkSqlParser.KW_NULL); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3349; this.match(SparkSqlParser.QUESTION); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3350; this.match(SparkSqlParser.COLON); this.state = 3351; this.identifier(); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 3352; this.interval(); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 3353; this.literalType(); this.state = 3354; this.stringLit(); } break; case 6: this.enterOuterAlt(_localctx, 6); { this.state = 3356; this.number(); } break; case 7: this.enterOuterAlt(_localctx, 7); { this.state = 3357; this.booleanValue(); } break; case 8: this.enterOuterAlt(_localctx, 8); { this.state = 3359; this._errHandler.sync(this); _alt = 1; do { switch (_alt) { case 1: { { this.state = 3358; this.stringLit(); } } break; default: throw new NoViableAltException(this); } this.state = 3361; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 435, this._ctx); } while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public comparisonOperator(): ComparisonOperatorContext { let _localctx: ComparisonOperatorContext = new ComparisonOperatorContext(this._ctx, this.state); this.enterRule(_localctx, 282, SparkSqlParser.RULE_comparisonOperator); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3365; _la = this._input.LA(1); if (!(((((_la - 344)) & ~0x1F) === 0 && ((1 << (_la - 344)) & ((1 << (SparkSqlParser.EQ - 344)) | (1 << (SparkSqlParser.NSEQ - 344)) | (1 << (SparkSqlParser.NEQ - 344)) | (1 << (SparkSqlParser.NEQJ - 344)) | (1 << (SparkSqlParser.LT - 344)) | (1 << (SparkSqlParser.LTE - 344)) | (1 << (SparkSqlParser.GT - 344)) | (1 << (SparkSqlParser.GTE - 344)))) !== 0))) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public arithmeticOperator(): ArithmeticOperatorContext { let _localctx: ArithmeticOperatorContext = new ArithmeticOperatorContext(this._ctx, this.state); this.enterRule(_localctx, 284, SparkSqlParser.RULE_arithmeticOperator); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3367; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DIV || ((((_la - 353)) & ~0x1F) === 0 && ((1 << (_la - 353)) & ((1 << (SparkSqlParser.PLUS - 353)) | (1 << (SparkSqlParser.MINUS - 353)) | (1 << (SparkSqlParser.ASTERISK - 353)) | (1 << (SparkSqlParser.SLASH - 353)) | (1 << (SparkSqlParser.PERCENT - 353)) | (1 << (SparkSqlParser.TILDE - 353)) | (1 << (SparkSqlParser.AMPERSAND - 353)) | (1 << (SparkSqlParser.PIPE - 353)) | (1 << (SparkSqlParser.CONCAT_PIPE - 353)) | (1 << (SparkSqlParser.HAT - 353)))) !== 0))) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public predicateOperator(): PredicateOperatorContext { let _localctx: PredicateOperatorContext = new PredicateOperatorContext(this._ctx, this.state); this.enterRule(_localctx, 286, SparkSqlParser.RULE_predicateOperator); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3369; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_AND || _la === SparkSqlParser.KW_IN || _la === SparkSqlParser.KW_NOT || _la === SparkSqlParser.KW_OR)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public booleanValue(): BooleanValueContext { let _localctx: BooleanValueContext = new BooleanValueContext(this._ctx, this.state); this.enterRule(_localctx, 288, SparkSqlParser.RULE_booleanValue); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3371; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FALSE || _la === SparkSqlParser.KW_TRUE)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public interval(): IntervalContext { let _localctx: IntervalContext = new IntervalContext(this._ctx, this.state); this.enterRule(_localctx, 290, SparkSqlParser.RULE_interval); try { this.enterOuterAlt(_localctx, 1); { this.state = 3373; this.match(SparkSqlParser.KW_INTERVAL); this.state = 3376; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 437, this._ctx) ) { case 1: { this.state = 3374; this.errorCapturingMultiUnitsInterval(); } break; case 2: { this.state = 3375; this.errorCapturingUnitToUnitInterval(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public errorCapturingMultiUnitsInterval(): ErrorCapturingMultiUnitsIntervalContext { let _localctx: ErrorCapturingMultiUnitsIntervalContext = new ErrorCapturingMultiUnitsIntervalContext(this._ctx, this.state); this.enterRule(_localctx, 292, SparkSqlParser.RULE_errorCapturingMultiUnitsInterval); try { this.enterOuterAlt(_localctx, 1); { this.state = 3378; _localctx._body = this.multiUnitsInterval(); this.state = 3380; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 438, this._ctx) ) { case 1: { this.state = 3379; this.unitToUnitInterval(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public multiUnitsInterval(): MultiUnitsIntervalContext { let _localctx: MultiUnitsIntervalContext = new MultiUnitsIntervalContext(this._ctx, this.state); this.enterRule(_localctx, 294, SparkSqlParser.RULE_multiUnitsInterval); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 3385; this._errHandler.sync(this); _alt = 1; do { switch (_alt) { case 1: { { this.state = 3382; this.intervalValue(); this.state = 3383; _localctx._unitInMultiUnits = this.unitInMultiUnits(); _localctx._unit.push(_localctx._unitInMultiUnits); } } break; default: throw new NoViableAltException(this); } this.state = 3387; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 439, this._ctx); } while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public errorCapturingUnitToUnitInterval(): ErrorCapturingUnitToUnitIntervalContext { let _localctx: ErrorCapturingUnitToUnitIntervalContext = new ErrorCapturingUnitToUnitIntervalContext(this._ctx, this.state); this.enterRule(_localctx, 296, SparkSqlParser.RULE_errorCapturingUnitToUnitInterval); try { this.enterOuterAlt(_localctx, 1); { this.state = 3389; _localctx._body = this.unitToUnitInterval(); this.state = 3392; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 440, this._ctx) ) { case 1: { this.state = 3390; _localctx._error1 = this.multiUnitsInterval(); } break; case 2: { this.state = 3391; _localctx._error2 = this.unitToUnitInterval(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unitToUnitInterval(): UnitToUnitIntervalContext { let _localctx: UnitToUnitIntervalContext = new UnitToUnitIntervalContext(this._ctx, this.state); this.enterRule(_localctx, 298, SparkSqlParser.RULE_unitToUnitInterval); try { this.enterOuterAlt(_localctx, 1); { this.state = 3394; _localctx._value = this.intervalValue(); this.state = 3395; this.unitInUnitToUnit(); this.state = 3396; this.match(SparkSqlParser.KW_TO); this.state = 3397; this.unitInUnitToUnit(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public intervalValue(): IntervalValueContext { let _localctx: IntervalValueContext = new IntervalValueContext(this._ctx, this.state); this.enterRule(_localctx, 300, SparkSqlParser.RULE_intervalValue); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3400; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 441, this._ctx) ) { case 1: { this.state = 3399; _la = this._input.LA(1); if (!(_la === SparkSqlParser.PLUS || _la === SparkSqlParser.MINUS)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; } this.state = 3405; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 442, this._ctx) ) { case 1: { this.state = 3402; this.match(SparkSqlParser.INTEGER_VALUE); } break; case 2: { this.state = 3403; this.match(SparkSqlParser.DECIMAL_VALUE); } break; case 3: { this.state = 3404; this.stringLit(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unitInMultiUnits(): UnitInMultiUnitsContext { let _localctx: UnitInMultiUnitsContext = new UnitInMultiUnitsContext(this._ctx, this.state); this.enterRule(_localctx, 302, SparkSqlParser.RULE_unitInMultiUnits); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3407; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DAY || _la === SparkSqlParser.KW_DAYS || _la === SparkSqlParser.KW_HOUR || _la === SparkSqlParser.KW_HOURS || ((((_la - 176)) & ~0x1F) === 0 && ((1 << (_la - 176)) & ((1 << (SparkSqlParser.KW_MICROSECOND - 176)) | (1 << (SparkSqlParser.KW_MICROSECONDS - 176)) | (1 << (SparkSqlParser.KW_MILLISECOND - 176)) | (1 << (SparkSqlParser.KW_MILLISECONDS - 176)) | (1 << (SparkSqlParser.KW_MINUTE - 176)) | (1 << (SparkSqlParser.KW_MINUTES - 176)) | (1 << (SparkSqlParser.KW_MONTH - 176)) | (1 << (SparkSqlParser.KW_MONTHS - 176)) | (1 << (SparkSqlParser.KW_NANOSECOND - 176)) | (1 << (SparkSqlParser.KW_NANOSECONDS - 176)))) !== 0) || _la === SparkSqlParser.KW_SECOND || _la === SparkSqlParser.KW_SECONDS || ((((_la - 334)) & ~0x1F) === 0 && ((1 << (_la - 334)) & ((1 << (SparkSqlParser.KW_WEEK - 334)) | (1 << (SparkSqlParser.KW_WEEKS - 334)) | (1 << (SparkSqlParser.KW_YEAR - 334)) | (1 << (SparkSqlParser.KW_YEARS - 334)))) !== 0))) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public unitInUnitToUnit(): UnitInUnitToUnitContext { let _localctx: UnitInUnitToUnitContext = new UnitInUnitToUnitContext(this._ctx, this.state); this.enterRule(_localctx, 304, SparkSqlParser.RULE_unitInUnitToUnit); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3409; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DAY || _la === SparkSqlParser.KW_HOUR || _la === SparkSqlParser.KW_MINUTE || _la === SparkSqlParser.KW_MONTH || _la === SparkSqlParser.KW_SECOND || _la === SparkSqlParser.KW_YEAR)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public colPosition(): ColPositionContext { let _localctx: ColPositionContext = new ColPositionContext(this._ctx, this.state); this.enterRule(_localctx, 306, SparkSqlParser.RULE_colPosition); try { this.state = 3414; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_FIRST: this.enterOuterAlt(_localctx, 1); { this.state = 3411; _localctx._position = this.match(SparkSqlParser.KW_FIRST); } break; case SparkSqlParser.KW_AFTER: this.enterOuterAlt(_localctx, 2); { this.state = 3412; _localctx._position = this.match(SparkSqlParser.KW_AFTER); this.state = 3413; _localctx._afterCol = this.errorCapturingIdentifier(); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public type(): TypeContext { let _localctx: TypeContext = new TypeContext(this._ctx, this.state); this.enterRule(_localctx, 308, SparkSqlParser.RULE_type); try { this.state = 3446; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 444, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3416; this.match(SparkSqlParser.KW_BOOLEAN); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3417; this.match(SparkSqlParser.KW_TINYINT); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3418; this.match(SparkSqlParser.KW_BYTE); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 3419; this.match(SparkSqlParser.KW_SMALLINT); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 3420; this.match(SparkSqlParser.KW_SHORT); } break; case 6: this.enterOuterAlt(_localctx, 6); { this.state = 3421; this.match(SparkSqlParser.KW_INT); } break; case 7: this.enterOuterAlt(_localctx, 7); { this.state = 3422; this.match(SparkSqlParser.KW_INTEGER); } break; case 8: this.enterOuterAlt(_localctx, 8); { this.state = 3423; this.match(SparkSqlParser.KW_BIGINT); } break; case 9: this.enterOuterAlt(_localctx, 9); { this.state = 3424; this.match(SparkSqlParser.KW_LONG); } break; case 10: this.enterOuterAlt(_localctx, 10); { this.state = 3425; this.match(SparkSqlParser.KW_FLOAT); } break; case 11: this.enterOuterAlt(_localctx, 11); { this.state = 3426; this.match(SparkSqlParser.KW_REAL); } break; case 12: this.enterOuterAlt(_localctx, 12); { this.state = 3427; this.match(SparkSqlParser.KW_DOUBLE); } break; case 13: this.enterOuterAlt(_localctx, 13); { this.state = 3428; this.match(SparkSqlParser.KW_DATE); } break; case 14: this.enterOuterAlt(_localctx, 14); { this.state = 3429; this.match(SparkSqlParser.KW_TIMESTAMP); } break; case 15: this.enterOuterAlt(_localctx, 15); { this.state = 3430; this.match(SparkSqlParser.KW_TIMESTAMP_NTZ); } break; case 16: this.enterOuterAlt(_localctx, 16); { this.state = 3431; this.match(SparkSqlParser.KW_TIMESTAMP_LTZ); } break; case 17: this.enterOuterAlt(_localctx, 17); { this.state = 3432; this.match(SparkSqlParser.KW_STRING); } break; case 18: this.enterOuterAlt(_localctx, 18); { this.state = 3433; this.match(SparkSqlParser.KW_CHARACTER); } break; case 19: this.enterOuterAlt(_localctx, 19); { this.state = 3434; this.match(SparkSqlParser.KW_CHAR); } break; case 20: this.enterOuterAlt(_localctx, 20); { this.state = 3435; this.match(SparkSqlParser.KW_VARCHAR); } break; case 21: this.enterOuterAlt(_localctx, 21); { this.state = 3436; this.match(SparkSqlParser.KW_BINARY); } break; case 22: this.enterOuterAlt(_localctx, 22); { this.state = 3437; this.match(SparkSqlParser.KW_DECIMAL); } break; case 23: this.enterOuterAlt(_localctx, 23); { this.state = 3438; this.match(SparkSqlParser.KW_DEC); } break; case 24: this.enterOuterAlt(_localctx, 24); { this.state = 3439; this.match(SparkSqlParser.KW_NUMERIC); } break; case 25: this.enterOuterAlt(_localctx, 25); { this.state = 3440; this.match(SparkSqlParser.KW_VOID); } break; case 26: this.enterOuterAlt(_localctx, 26); { this.state = 3441; this.match(SparkSqlParser.KW_INTERVAL); } break; case 27: this.enterOuterAlt(_localctx, 27); { this.state = 3442; this.match(SparkSqlParser.KW_ARRAY); } break; case 28: this.enterOuterAlt(_localctx, 28); { this.state = 3443; this.match(SparkSqlParser.KW_STRUCT); } break; case 29: this.enterOuterAlt(_localctx, 29); { this.state = 3444; this.match(SparkSqlParser.KW_MAP); } break; case 30: this.enterOuterAlt(_localctx, 30); { this.state = 3445; _localctx._unsupportedType = this.identifier(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public dataType(): DataTypeContext { let _localctx: DataTypeContext = new DataTypeContext(this._ctx, this.state); this.enterRule(_localctx, 310, SparkSqlParser.RULE_dataType); let _la: number; try { this.state = 3494; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 451, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3448; _localctx._complex = this.match(SparkSqlParser.KW_ARRAY); this.state = 3449; this.match(SparkSqlParser.LT); this.state = 3450; this.dataType(); this.state = 3451; this.match(SparkSqlParser.GT); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3453; _localctx._complex = this.match(SparkSqlParser.KW_MAP); this.state = 3454; this.match(SparkSqlParser.LT); this.state = 3455; this.dataType(); this.state = 3456; this.match(SparkSqlParser.COMMA); this.state = 3457; this.dataType(); this.state = 3458; this.match(SparkSqlParser.GT); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3460; _localctx._complex = this.match(SparkSqlParser.KW_STRUCT); this.state = 3467; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.LT: { this.state = 3461; this.match(SparkSqlParser.LT); this.state = 3463; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 445, this._ctx) ) { case 1: { this.state = 3462; this.complexColTypeList(); } break; } this.state = 3465; this.match(SparkSqlParser.GT); } break; case SparkSqlParser.NEQ: { this.state = 3466; this.match(SparkSqlParser.NEQ); } break; default: throw new NoViableAltException(this); } } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 3469; this.match(SparkSqlParser.KW_INTERVAL); this.state = 3470; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_MONTH || _la === SparkSqlParser.KW_YEAR)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3473; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 447, this._ctx) ) { case 1: { this.state = 3471; this.match(SparkSqlParser.KW_TO); this.state = 3472; this.match(SparkSqlParser.KW_MONTH); } break; } } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 3475; this.match(SparkSqlParser.KW_INTERVAL); this.state = 3476; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DAY || _la === SparkSqlParser.KW_HOUR || _la === SparkSqlParser.KW_MINUTE || _la === SparkSqlParser.KW_SECOND)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3479; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 448, this._ctx) ) { case 1: { this.state = 3477; this.match(SparkSqlParser.KW_TO); this.state = 3478; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_HOUR || _la === SparkSqlParser.KW_MINUTE || _la === SparkSqlParser.KW_SECOND)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; } } break; case 6: this.enterOuterAlt(_localctx, 6); { this.state = 3481; this.type(); this.state = 3492; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 450, this._ctx) ) { case 1: { this.state = 3482; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3483; this.match(SparkSqlParser.INTEGER_VALUE); this.state = 3488; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3484; this.match(SparkSqlParser.COMMA); this.state = 3485; this.match(SparkSqlParser.INTEGER_VALUE); } } this.state = 3490; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 3491; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public qualifiedColTypeWithPositionList(): QualifiedColTypeWithPositionListContext { let _localctx: QualifiedColTypeWithPositionListContext = new QualifiedColTypeWithPositionListContext(this._ctx, this.state); this.enterRule(_localctx, 312, SparkSqlParser.RULE_qualifiedColTypeWithPositionList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3496; this.qualifiedColTypeWithPosition(); this.state = 3501; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3497; this.match(SparkSqlParser.COMMA); this.state = 3498; this.qualifiedColTypeWithPosition(); } } this.state = 3503; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public qualifiedColTypeWithPosition(): QualifiedColTypeWithPositionContext { let _localctx: QualifiedColTypeWithPositionContext = new QualifiedColTypeWithPositionContext(this._ctx, this.state); this.enterRule(_localctx, 314, SparkSqlParser.RULE_qualifiedColTypeWithPosition); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 3504; _localctx._name = this.multipartIdentifier(); this.state = 3505; this.dataType(); this.state = 3509; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 453, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 3506; this.colDefinitionDescriptorWithPosition(); } } } this.state = 3511; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 453, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public colDefinitionDescriptorWithPosition(): ColDefinitionDescriptorWithPositionContext { let _localctx: ColDefinitionDescriptorWithPositionContext = new ColDefinitionDescriptorWithPositionContext(this._ctx, this.state); this.enterRule(_localctx, 316, SparkSqlParser.RULE_colDefinitionDescriptorWithPosition); try { this.state = 3517; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_NOT: this.enterOuterAlt(_localctx, 1); { this.state = 3512; this.match(SparkSqlParser.KW_NOT); this.state = 3513; this.match(SparkSqlParser.KW_NULL); } break; case SparkSqlParser.KW_DEFAULT: this.enterOuterAlt(_localctx, 2); { this.state = 3514; this.defaultExpression(); } break; case SparkSqlParser.KW_COMMENT: this.enterOuterAlt(_localctx, 3); { this.state = 3515; this.commentSpec(); } break; case SparkSqlParser.KW_AFTER: case SparkSqlParser.KW_FIRST: this.enterOuterAlt(_localctx, 4); { this.state = 3516; this.colPosition(); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public defaultExpression(): DefaultExpressionContext { let _localctx: DefaultExpressionContext = new DefaultExpressionContext(this._ctx, this.state); this.enterRule(_localctx, 318, SparkSqlParser.RULE_defaultExpression); try { this.enterOuterAlt(_localctx, 1); { this.state = 3519; this.match(SparkSqlParser.KW_DEFAULT); this.state = 3520; this.expression(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public variableDefaultExpression(): VariableDefaultExpressionContext { let _localctx: VariableDefaultExpressionContext = new VariableDefaultExpressionContext(this._ctx, this.state); this.enterRule(_localctx, 320, SparkSqlParser.RULE_variableDefaultExpression); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3522; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DEFAULT || _la === SparkSqlParser.EQ)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3523; this.expression(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public colTypeList(): ColTypeListContext { let _localctx: ColTypeListContext = new ColTypeListContext(this._ctx, this.state); this.enterRule(_localctx, 322, SparkSqlParser.RULE_colTypeList); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 3525; this.colType(); this.state = 3530; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 455, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 3526; this.match(SparkSqlParser.COMMA); this.state = 3527; this.colType(); } } } this.state = 3532; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 455, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public colType(): ColTypeContext { let _localctx: ColTypeContext = new ColTypeContext(this._ctx, this.state); this.enterRule(_localctx, 324, SparkSqlParser.RULE_colType); try { this.enterOuterAlt(_localctx, 1); { this.state = 3533; _localctx._colName = this.errorCapturingIdentifier(); this.state = 3534; this.dataType(); this.state = 3537; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 456, this._ctx) ) { case 1: { this.state = 3535; this.match(SparkSqlParser.KW_NOT); this.state = 3536; this.match(SparkSqlParser.KW_NULL); } break; } this.state = 3540; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 457, this._ctx) ) { case 1: { this.state = 3539; this.commentSpec(); } break; } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public createOrReplaceTableColTypeList(): CreateOrReplaceTableColTypeListContext { let _localctx: CreateOrReplaceTableColTypeListContext = new CreateOrReplaceTableColTypeListContext(this._ctx, this.state); this.enterRule(_localctx, 326, SparkSqlParser.RULE_createOrReplaceTableColTypeList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3542; this.createOrReplaceTableColType(); this.state = 3547; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3543; this.match(SparkSqlParser.COMMA); this.state = 3544; this.createOrReplaceTableColType(); } } this.state = 3549; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public createOrReplaceTableColType(): CreateOrReplaceTableColTypeContext { let _localctx: CreateOrReplaceTableColTypeContext = new CreateOrReplaceTableColTypeContext(this._ctx, this.state); this.enterRule(_localctx, 328, SparkSqlParser.RULE_createOrReplaceTableColType); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3550; _localctx._colName = this.errorCapturingIdentifier(); this.state = 3551; this.dataType(); this.state = 3555; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.KW_COMMENT || _la === SparkSqlParser.KW_DEFAULT || _la === SparkSqlParser.KW_GENERATED || _la === SparkSqlParser.KW_NOT) { { { this.state = 3552; this.colDefinitionOption(); } } this.state = 3557; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public colDefinitionOption(): ColDefinitionOptionContext { let _localctx: ColDefinitionOptionContext = new ColDefinitionOptionContext(this._ctx, this.state); this.enterRule(_localctx, 330, SparkSqlParser.RULE_colDefinitionOption); try { this.state = 3563; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_NOT: this.enterOuterAlt(_localctx, 1); { this.state = 3558; this.match(SparkSqlParser.KW_NOT); this.state = 3559; this.match(SparkSqlParser.KW_NULL); } break; case SparkSqlParser.KW_DEFAULT: this.enterOuterAlt(_localctx, 2); { this.state = 3560; this.defaultExpression(); } break; case SparkSqlParser.KW_GENERATED: this.enterOuterAlt(_localctx, 3); { this.state = 3561; this.generationExpression(); } break; case SparkSqlParser.KW_COMMENT: this.enterOuterAlt(_localctx, 4); { this.state = 3562; this.commentSpec(); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public generationExpression(): GenerationExpressionContext { let _localctx: GenerationExpressionContext = new GenerationExpressionContext(this._ctx, this.state); this.enterRule(_localctx, 332, SparkSqlParser.RULE_generationExpression); try { this.enterOuterAlt(_localctx, 1); { this.state = 3565; this.match(SparkSqlParser.KW_GENERATED); this.state = 3566; this.match(SparkSqlParser.KW_ALWAYS); this.state = 3567; this.match(SparkSqlParser.KW_AS); this.state = 3568; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3569; this.expression(); this.state = 3570; this.match(SparkSqlParser.RIGHT_PAREN); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public complexColTypeList(): ComplexColTypeListContext { let _localctx: ComplexColTypeListContext = new ComplexColTypeListContext(this._ctx, this.state); this.enterRule(_localctx, 334, SparkSqlParser.RULE_complexColTypeList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3572; this.complexColType(); this.state = 3577; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3573; this.match(SparkSqlParser.COMMA); this.state = 3574; this.complexColType(); } } this.state = 3579; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public complexColType(): ComplexColTypeContext { let _localctx: ComplexColTypeContext = new ComplexColTypeContext(this._ctx, this.state); this.enterRule(_localctx, 336, SparkSqlParser.RULE_complexColType); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3580; this.identifier(); this.state = 3582; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 462, this._ctx) ) { case 1: { this.state = 3581; this.match(SparkSqlParser.COLON); } break; } this.state = 3584; this.dataType(); this.state = 3587; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_NOT) { { this.state = 3585; this.match(SparkSqlParser.KW_NOT); this.state = 3586; this.match(SparkSqlParser.KW_NULL); } } this.state = 3590; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_COMMENT) { { this.state = 3589; this.commentSpec(); } } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public whenClause(): WhenClauseContext { let _localctx: WhenClauseContext = new WhenClauseContext(this._ctx, this.state); this.enterRule(_localctx, 338, SparkSqlParser.RULE_whenClause); try { this.enterOuterAlt(_localctx, 1); { this.state = 3592; this.match(SparkSqlParser.KW_WHEN); this.state = 3593; _localctx._condition = this.expression(); this.state = 3594; this.match(SparkSqlParser.KW_THEN); this.state = 3595; _localctx._result = this.expression(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public windowClause(): WindowClauseContext { let _localctx: WindowClauseContext = new WindowClauseContext(this._ctx, this.state); this.enterRule(_localctx, 340, SparkSqlParser.RULE_windowClause); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 3597; this.match(SparkSqlParser.KW_WINDOW); this.state = 3598; this.namedWindow(); this.state = 3603; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 465, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 3599; this.match(SparkSqlParser.COMMA); this.state = 3600; this.namedWindow(); } } } this.state = 3605; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 465, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public namedWindow(): NamedWindowContext { let _localctx: NamedWindowContext = new NamedWindowContext(this._ctx, this.state); this.enterRule(_localctx, 342, SparkSqlParser.RULE_namedWindow); try { this.enterOuterAlt(_localctx, 1); { this.state = 3606; _localctx._name = this.errorCapturingIdentifier(); this.state = 3607; this.match(SparkSqlParser.KW_AS); this.state = 3608; this.windowSpec(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public windowSpec(): WindowSpecContext { let _localctx: WindowSpecContext = new WindowSpecContext(this._ctx, this.state); this.enterRule(_localctx, 344, SparkSqlParser.RULE_windowSpec); let _la: number; try { this.state = 3656; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 473, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3610; _localctx._name = this.errorCapturingIdentifier(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3611; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3612; _localctx._name = this.errorCapturingIdentifier(); this.state = 3613; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3615; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3650; this._errHandler.sync(this); switch (this._input.LA(1)) { case SparkSqlParser.KW_CLUSTER: { this.state = 3616; this.match(SparkSqlParser.KW_CLUSTER); this.state = 3617; this.match(SparkSqlParser.KW_BY); this.state = 3618; _localctx._expression = this.expression(); _localctx._partition.push(_localctx._expression); this.state = 3623; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3619; this.match(SparkSqlParser.COMMA); this.state = 3620; _localctx._expression = this.expression(); _localctx._partition.push(_localctx._expression); } } this.state = 3625; this._errHandler.sync(this); _la = this._input.LA(1); } } break; case SparkSqlParser.RIGHT_PAREN: case SparkSqlParser.KW_DISTRIBUTE: case SparkSqlParser.KW_ORDER: case SparkSqlParser.KW_PARTITION: case SparkSqlParser.KW_RANGE: case SparkSqlParser.KW_ROWS: case SparkSqlParser.KW_SORT: { this.state = 3636; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_DISTRIBUTE || _la === SparkSqlParser.KW_PARTITION) { { this.state = 3626; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DISTRIBUTE || _la === SparkSqlParser.KW_PARTITION)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3627; this.match(SparkSqlParser.KW_BY); this.state = 3628; _localctx._expression = this.expression(); _localctx._partition.push(_localctx._expression); this.state = 3633; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3629; this.match(SparkSqlParser.COMMA); this.state = 3630; _localctx._expression = this.expression(); _localctx._partition.push(_localctx._expression); } } this.state = 3635; this._errHandler.sync(this); _la = this._input.LA(1); } } } this.state = 3648; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_ORDER || _la === SparkSqlParser.KW_SORT) { { this.state = 3638; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ORDER || _la === SparkSqlParser.KW_SORT)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3639; this.match(SparkSqlParser.KW_BY); this.state = 3640; this.sortItem(); this.state = 3645; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3641; this.match(SparkSqlParser.COMMA); this.state = 3642; this.sortItem(); } } this.state = 3647; this._errHandler.sync(this); _la = this._input.LA(1); } } } } break; default: throw new NoViableAltException(this); } this.state = 3653; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.KW_RANGE || _la === SparkSqlParser.KW_ROWS) { { this.state = 3652; this.windowFrame(); } } this.state = 3655; this.match(SparkSqlParser.RIGHT_PAREN); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public windowFrame(): WindowFrameContext { let _localctx: WindowFrameContext = new WindowFrameContext(this._ctx, this.state); this.enterRule(_localctx, 346, SparkSqlParser.RULE_windowFrame); try { this.state = 3674; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 474, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3658; _localctx._frameType = this.match(SparkSqlParser.KW_RANGE); this.state = 3659; _localctx._start_ = this.frameBound(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3660; _localctx._frameType = this.match(SparkSqlParser.KW_ROWS); this.state = 3661; _localctx._start_ = this.frameBound(); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3662; _localctx._frameType = this.match(SparkSqlParser.KW_RANGE); this.state = 3663; this.match(SparkSqlParser.KW_BETWEEN); this.state = 3664; _localctx._start_ = this.frameBound(); this.state = 3665; this.match(SparkSqlParser.KW_AND); this.state = 3666; _localctx._end = this.frameBound(); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 3668; _localctx._frameType = this.match(SparkSqlParser.KW_ROWS); this.state = 3669; this.match(SparkSqlParser.KW_BETWEEN); this.state = 3670; _localctx._start_ = this.frameBound(); this.state = 3671; this.match(SparkSqlParser.KW_AND); this.state = 3672; _localctx._end = this.frameBound(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public frameBound(): FrameBoundContext { let _localctx: FrameBoundContext = new FrameBoundContext(this._ctx, this.state); this.enterRule(_localctx, 348, SparkSqlParser.RULE_frameBound); let _la: number; try { this.state = 3683; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 475, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3676; this.match(SparkSqlParser.KW_UNBOUNDED); this.state = 3677; _localctx._boundType = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FOLLOWING || _la === SparkSqlParser.KW_PRECEDING)) { _localctx._boundType = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3678; _localctx._boundType = this.match(SparkSqlParser.KW_CURRENT); this.state = 3679; this.match(SparkSqlParser.KW_ROW); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3680; this.expression(); this.state = 3681; _localctx._boundType = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_FOLLOWING || _la === SparkSqlParser.KW_PRECEDING)) { _localctx._boundType = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public qualifiedNameList(): QualifiedNameListContext { let _localctx: QualifiedNameListContext = new QualifiedNameListContext(this._ctx, this.state); this.enterRule(_localctx, 350, SparkSqlParser.RULE_qualifiedNameList); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3685; this.qualifiedName(); this.state = 3690; this._errHandler.sync(this); _la = this._input.LA(1); while (_la === SparkSqlParser.COMMA) { { { this.state = 3686; this.match(SparkSqlParser.COMMA); this.state = 3687; this.qualifiedName(); } } this.state = 3692; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public functionName(): FunctionNameContext { let _localctx: FunctionNameContext = new FunctionNameContext(this._ctx, this.state); this.enterRule(_localctx, 352, SparkSqlParser.RULE_functionName); try { this.state = 3702; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 477, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3693; this.match(SparkSqlParser.KW_IDENTIFIER_KW); this.state = 3694; this.match(SparkSqlParser.LEFT_PAREN); this.state = 3695; this.expression(); this.state = 3696; this.match(SparkSqlParser.RIGHT_PAREN); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3698; this.qualifiedName(); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3699; this.match(SparkSqlParser.KW_FILTER); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 3700; this.match(SparkSqlParser.KW_LEFT); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 3701; this.match(SparkSqlParser.KW_RIGHT); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public functionNameCreate(): FunctionNameCreateContext { let _localctx: FunctionNameCreateContext = new FunctionNameCreateContext(this._ctx, this.state); this.enterRule(_localctx, 354, SparkSqlParser.RULE_functionNameCreate); try { this.enterOuterAlt(_localctx, 1); { this.state = 3704; this.qualifiedName(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public qualifiedName(): QualifiedNameContext { let _localctx: QualifiedNameContext = new QualifiedNameContext(this._ctx, this.state); this.enterRule(_localctx, 356, SparkSqlParser.RULE_qualifiedName); try { let _alt: number; this.enterOuterAlt(_localctx, 1); { this.state = 3706; this.identifier(); this.state = 3711; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 478, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { { { this.state = 3707; this.match(SparkSqlParser.DOT); this.state = 3708; this.identifier(); } } } this.state = 3713; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 478, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public errorCapturingIdentifier(): ErrorCapturingIdentifierContext { let _localctx: ErrorCapturingIdentifierContext = new ErrorCapturingIdentifierContext(this._ctx, this.state); this.enterRule(_localctx, 358, SparkSqlParser.RULE_errorCapturingIdentifier); try { this.enterOuterAlt(_localctx, 1); { this.state = 3714; this.identifier(); this.state = 3715; this.errorCapturingIdentifierExtra(); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public errorCapturingIdentifierExtra(): ErrorCapturingIdentifierExtraContext { let _localctx: ErrorCapturingIdentifierExtraContext = new ErrorCapturingIdentifierExtraContext(this._ctx, this.state); this.enterRule(_localctx, 360, SparkSqlParser.RULE_errorCapturingIdentifierExtra); try { let _alt: number; this.state = 3724; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 480, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3719; this._errHandler.sync(this); _alt = 1; do { switch (_alt) { case 1: { { this.state = 3717; this.match(SparkSqlParser.MINUS); this.state = 3718; this.identifier(); } } break; default: throw new NoViableAltException(this); } this.state = 3721; this._errHandler.sync(this); _alt = this.interpreter.adaptivePredict(this._input, 479, this._ctx); } while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER); } break; case 2: this.enterOuterAlt(_localctx, 2); // tslint:disable-next-line:no-empty { } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public identifier(): IdentifierContext { let _localctx: IdentifierContext = new IdentifierContext(this._ctx, this.state); this.enterRule(_localctx, 362, SparkSqlParser.RULE_identifier); try { this.state = 3729; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 481, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3726; this.strictIdentifier(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3727; if (!(!this.SQL_standard_keyword_behavior)) { throw this.createFailedPredicateException("!this.SQL_standard_keyword_behavior"); } this.state = 3728; this.strictNonReserved(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public strictIdentifier(): StrictIdentifierContext { let _localctx: StrictIdentifierContext = new StrictIdentifierContext(this._ctx, this.state); this.enterRule(_localctx, 364, SparkSqlParser.RULE_strictIdentifier); try { this.state = 3737; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 482, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3731; this.match(SparkSqlParser.IDENTIFIER); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3732; this.quotedIdentifier(); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3733; if (!(this.SQL_standard_keyword_behavior)) { throw this.createFailedPredicateException("this.SQL_standard_keyword_behavior"); } this.state = 3734; this.ansiNonReserved(); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 3735; if (!(!this.SQL_standard_keyword_behavior)) { throw this.createFailedPredicateException("!this.SQL_standard_keyword_behavior"); } this.state = 3736; this.nonReserved(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public quotedIdentifier(): QuotedIdentifierContext { let _localctx: QuotedIdentifierContext = new QuotedIdentifierContext(this._ctx, this.state); this.enterRule(_localctx, 366, SparkSqlParser.RULE_quotedIdentifier); try { this.state = 3742; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 483, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3739; this.match(SparkSqlParser.BACKQUOTED_IDENTIFIER); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3740; if (!(this.double_quoted_identifiers)) { throw this.createFailedPredicateException("this.double_quoted_identifiers"); } this.state = 3741; this.match(SparkSqlParser.DOUBLEQUOTED_STRING); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public backQuotedIdentifier(): BackQuotedIdentifierContext { let _localctx: BackQuotedIdentifierContext = new BackQuotedIdentifierContext(this._ctx, this.state); this.enterRule(_localctx, 368, SparkSqlParser.RULE_backQuotedIdentifier); try { this.enterOuterAlt(_localctx, 1); { this.state = 3744; this.match(SparkSqlParser.BACKQUOTED_IDENTIFIER); } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public number(): NumberContext { let _localctx: NumberContext = new NumberContext(this._ctx, this.state); this.enterRule(_localctx, 370, SparkSqlParser.RULE_number); let _la: number; try { this.state = 3789; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 494, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3746; if (!(!this.legacy_exponent_literal_as_decimal_enabled)) { throw this.createFailedPredicateException("!this.legacy_exponent_literal_as_decimal_enabled"); } this.state = 3748; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 3747; this.match(SparkSqlParser.MINUS); } } this.state = 3750; this.match(SparkSqlParser.EXPONENT_VALUE); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3751; if (!(!this.legacy_exponent_literal_as_decimal_enabled)) { throw this.createFailedPredicateException("!this.legacy_exponent_literal_as_decimal_enabled"); } this.state = 3753; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 3752; this.match(SparkSqlParser.MINUS); } } this.state = 3755; this.match(SparkSqlParser.DECIMAL_VALUE); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3756; if (!(this.legacy_exponent_literal_as_decimal_enabled)) { throw this.createFailedPredicateException("this.legacy_exponent_literal_as_decimal_enabled"); } this.state = 3758; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 3757; this.match(SparkSqlParser.MINUS); } } this.state = 3760; _la = this._input.LA(1); if (!(_la === SparkSqlParser.EXPONENT_VALUE || _la === SparkSqlParser.DECIMAL_VALUE)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 3762; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 3761; this.match(SparkSqlParser.MINUS); } } this.state = 3764; this.match(SparkSqlParser.INTEGER_VALUE); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 3766; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 3765; this.match(SparkSqlParser.MINUS); } } this.state = 3768; this.match(SparkSqlParser.BIGINT_LITERAL); } break; case 6: this.enterOuterAlt(_localctx, 6); { this.state = 3770; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 3769; this.match(SparkSqlParser.MINUS); } } this.state = 3772; this.match(SparkSqlParser.SMALLINT_LITERAL); } break; case 7: this.enterOuterAlt(_localctx, 7); { this.state = 3774; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 3773; this.match(SparkSqlParser.MINUS); } } this.state = 3776; this.match(SparkSqlParser.TINYINT_LITERAL); } break; case 8: this.enterOuterAlt(_localctx, 8); { this.state = 3778; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 3777; this.match(SparkSqlParser.MINUS); } } this.state = 3780; this.match(SparkSqlParser.DOUBLE_LITERAL); } break; case 9: this.enterOuterAlt(_localctx, 9); { this.state = 3782; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 3781; this.match(SparkSqlParser.MINUS); } } this.state = 3784; this.match(SparkSqlParser.FLOAT_LITERAL); } break; case 10: this.enterOuterAlt(_localctx, 10); { this.state = 3786; this._errHandler.sync(this); _la = this._input.LA(1); if (_la === SparkSqlParser.MINUS) { { this.state = 3785; this.match(SparkSqlParser.MINUS); } } this.state = 3788; this.match(SparkSqlParser.BIGDECIMAL_LITERAL); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public alterColumnAction(): AlterColumnActionContext { let _localctx: AlterColumnActionContext = new AlterColumnActionContext(this._ctx, this.state); this.enterRule(_localctx, 372, SparkSqlParser.RULE_alterColumnAction); let _la: number; try { this.state = 3802; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 495, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3791; this.match(SparkSqlParser.KW_TYPE); this.state = 3792; this.dataType(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3793; this.commentSpec(); } break; case 3: this.enterOuterAlt(_localctx, 3); { this.state = 3794; this.colPosition(); } break; case 4: this.enterOuterAlt(_localctx, 4); { this.state = 3795; _localctx._setOrDrop = this._input.LT(1); _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_DROP || _la === SparkSqlParser.KW_SET)) { _localctx._setOrDrop = this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } this.state = 3796; this.match(SparkSqlParser.KW_NOT); this.state = 3797; this.match(SparkSqlParser.KW_NULL); } break; case 5: this.enterOuterAlt(_localctx, 5); { this.state = 3798; this.match(SparkSqlParser.KW_SET); this.state = 3799; this.defaultExpression(); } break; case 6: this.enterOuterAlt(_localctx, 6); { this.state = 3800; _localctx._dropDefault = this.match(SparkSqlParser.KW_DROP); this.state = 3801; this.match(SparkSqlParser.KW_DEFAULT); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public stringLit(): StringLitContext { let _localctx: StringLitContext = new StringLitContext(this._ctx, this.state); this.enterRule(_localctx, 374, SparkSqlParser.RULE_stringLit); try { this.state = 3807; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 496, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3804; this.match(SparkSqlParser.STRING_LITERAL); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3805; if (!(!this.double_quoted_identifiers)) { throw this.createFailedPredicateException("!this.double_quoted_identifiers"); } this.state = 3806; this.match(SparkSqlParser.DOUBLEQUOTED_STRING); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public comment(): CommentContext { let _localctx: CommentContext = new CommentContext(this._ctx, this.state); this.enterRule(_localctx, 376, SparkSqlParser.RULE_comment); try { this.state = 3811; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 497, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3809; this.stringLit(); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3810; this.match(SparkSqlParser.KW_NULL); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public version(): VersionContext { let _localctx: VersionContext = new VersionContext(this._ctx, this.state); this.enterRule(_localctx, 378, SparkSqlParser.RULE_version); try { this.state = 3815; this._errHandler.sync(this); switch ( this.interpreter.adaptivePredict(this._input, 498, this._ctx) ) { case 1: this.enterOuterAlt(_localctx, 1); { this.state = 3813; this.match(SparkSqlParser.INTEGER_VALUE); } break; case 2: this.enterOuterAlt(_localctx, 2); { this.state = 3814; this.stringLit(); } break; } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public ansiNonReserved(): AnsiNonReservedContext { let _localctx: AnsiNonReservedContext = new AnsiNonReservedContext(this._ctx, this.state); this.enterRule(_localctx, 380, SparkSqlParser.RULE_ansiNonReserved); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3817; _la = this._input.LA(1); if (!((((_la) & ~0x1F) === 0 && ((1 << _la) & ((1 << SparkSqlParser.KW_ADD) | (1 << SparkSqlParser.KW_AFTER) | (1 << SparkSqlParser.KW_ALTER) | (1 << SparkSqlParser.KW_ALWAYS) | (1 << SparkSqlParser.KW_ANALYZE) | (1 << SparkSqlParser.KW_ANTI) | (1 << SparkSqlParser.KW_ANY_VALUE) | (1 << SparkSqlParser.KW_ARCHIVE) | (1 << SparkSqlParser.KW_ARRAY) | (1 << SparkSqlParser.KW_ASC) | (1 << SparkSqlParser.KW_AT) | (1 << SparkSqlParser.KW_BETWEEN) | (1 << SparkSqlParser.KW_BIGINT) | (1 << SparkSqlParser.KW_BINARY) | (1 << SparkSqlParser.KW_BOOLEAN) | (1 << SparkSqlParser.KW_BUCKET) | (1 << SparkSqlParser.KW_BUCKETS) | (1 << SparkSqlParser.KW_BY))) !== 0) || ((((_la - 32)) & ~0x1F) === 0 && ((1 << (_la - 32)) & ((1 << (SparkSqlParser.KW_BYTE - 32)) | (1 << (SparkSqlParser.KW_CACHE - 32)) | (1 << (SparkSqlParser.KW_CASCADE - 32)) | (1 << (SparkSqlParser.KW_CATALOG - 32)) | (1 << (SparkSqlParser.KW_CATALOGS - 32)) | (1 << (SparkSqlParser.KW_CHANGE - 32)) | (1 << (SparkSqlParser.KW_CHAR - 32)) | (1 << (SparkSqlParser.KW_CHARACTER - 32)) | (1 << (SparkSqlParser.KW_CLEAR - 32)) | (1 << (SparkSqlParser.KW_CLUSTER - 32)) | (1 << (SparkSqlParser.KW_CLUSTERED - 32)) | (1 << (SparkSqlParser.KW_CODEGEN - 32)) | (1 << (SparkSqlParser.KW_COLLECTION - 32)) | (1 << (SparkSqlParser.KW_COLUMNS - 32)) | (1 << (SparkSqlParser.KW_COMMENT - 32)) | (1 << (SparkSqlParser.KW_COMMIT - 32)) | (1 << (SparkSqlParser.KW_COMPACT - 32)) | (1 << (SparkSqlParser.KW_COMPACTIONS - 32)) | (1 << (SparkSqlParser.KW_COMPUTE - 32)) | (1 << (SparkSqlParser.KW_CONCATENATE - 32)) | (1 << (SparkSqlParser.KW_COST - 32)) | (1 << (SparkSqlParser.KW_CUBE - 32)) | (1 << (SparkSqlParser.KW_CURRENT - 32)))) !== 0) || ((((_la - 67)) & ~0x1F) === 0 && ((1 << (_la - 67)) & ((1 << (SparkSqlParser.KW_DAY - 67)) | (1 << (SparkSqlParser.KW_DAYS - 67)) | (1 << (SparkSqlParser.KW_DAYOFYEAR - 67)) | (1 << (SparkSqlParser.KW_DATA - 67)) | (1 << (SparkSqlParser.KW_DATE - 67)) | (1 << (SparkSqlParser.KW_DATABASE - 67)) | (1 << (SparkSqlParser.KW_DATABASES - 67)) | (1 << (SparkSqlParser.KW_DATEADD - 67)) | (1 << (SparkSqlParser.KW_DATE_ADD - 67)) | (1 << (SparkSqlParser.KW_DATEDIFF - 67)) | (1 << (SparkSqlParser.KW_DATE_DIFF - 67)) | (1 << (SparkSqlParser.KW_DBPROPERTIES - 67)) | (1 << (SparkSqlParser.KW_DEC - 67)) | (1 << (SparkSqlParser.KW_DECIMAL - 67)) | (1 << (SparkSqlParser.KW_DECLARE - 67)) | (1 << (SparkSqlParser.KW_DEFAULT - 67)) | (1 << (SparkSqlParser.KW_DEFINED - 67)) | (1 << (SparkSqlParser.KW_DELETE - 67)) | (1 << (SparkSqlParser.KW_DELIMITED - 67)) | (1 << (SparkSqlParser.KW_DESC - 67)) | (1 << (SparkSqlParser.KW_DESCRIBE - 67)) | (1 << (SparkSqlParser.KW_DFS - 67)) | (1 << (SparkSqlParser.KW_DIRECTORIES - 67)) | (1 << (SparkSqlParser.KW_DIRECTORY - 67)) | (1 << (SparkSqlParser.KW_DISTRIBUTE - 67)) | (1 << (SparkSqlParser.KW_DIV - 67)) | (1 << (SparkSqlParser.KW_DOUBLE - 67)) | (1 << (SparkSqlParser.KW_DROP - 67)))) !== 0) || ((((_la - 99)) & ~0x1F) === 0 && ((1 << (_la - 99)) & ((1 << (SparkSqlParser.KW_ESCAPED - 99)) | (1 << (SparkSqlParser.KW_EXCHANGE - 99)) | (1 << (SparkSqlParser.KW_EXCLUDE - 99)) | (1 << (SparkSqlParser.KW_EXISTS - 99)) | (1 << (SparkSqlParser.KW_EXPLAIN - 99)) | (1 << (SparkSqlParser.KW_EXPORT - 99)) | (1 << (SparkSqlParser.KW_EXTENDED - 99)) | (1 << (SparkSqlParser.KW_EXTERNAL - 99)) | (1 << (SparkSqlParser.KW_EXTRACT - 99)) | (1 << (SparkSqlParser.KW_FIELDS - 99)) | (1 << (SparkSqlParser.KW_FILEFORMAT - 99)) | (1 << (SparkSqlParser.KW_FIRST - 99)) | (1 << (SparkSqlParser.KW_FLOAT - 99)) | (1 << (SparkSqlParser.KW_FOLLOWING - 99)) | (1 << (SparkSqlParser.KW_FORMAT - 99)) | (1 << (SparkSqlParser.KW_FORMATTED - 99)) | (1 << (SparkSqlParser.KW_FUNCTION - 99)) | (1 << (SparkSqlParser.KW_FUNCTIONS - 99)) | (1 << (SparkSqlParser.KW_GENERATED - 99)) | (1 << (SparkSqlParser.KW_GLOBAL - 99)) | (1 << (SparkSqlParser.KW_GROUPING - 99)))) !== 0) || ((((_la - 131)) & ~0x1F) === 0 && ((1 << (_la - 131)) & ((1 << (SparkSqlParser.KW_BINARY_HEX - 131)) | (1 << (SparkSqlParser.KW_HOUR - 131)) | (1 << (SparkSqlParser.KW_HOURS - 131)) | (1 << (SparkSqlParser.KW_IDENTIFIER_KW - 131)) | (1 << (SparkSqlParser.KW_IF - 131)) | (1 << (SparkSqlParser.KW_IGNORE - 131)) | (1 << (SparkSqlParser.KW_IMPORT - 131)) | (1 << (SparkSqlParser.KW_INCLUDE - 131)) | (1 << (SparkSqlParser.KW_INDEX - 131)) | (1 << (SparkSqlParser.KW_INDEXES - 131)) | (1 << (SparkSqlParser.KW_INPATH - 131)) | (1 << (SparkSqlParser.KW_INPUTFORMAT - 131)) | (1 << (SparkSqlParser.KW_INSERT - 131)) | (1 << (SparkSqlParser.KW_INTERVAL - 131)) | (1 << (SparkSqlParser.KW_INT - 131)) | (1 << (SparkSqlParser.KW_INTEGER - 131)) | (1 << (SparkSqlParser.KW_ITEMS - 131)) | (1 << (SparkSqlParser.KW_KEYS - 131)) | (1 << (SparkSqlParser.KW_LAST - 131)) | (1 << (SparkSqlParser.KW_LAZY - 131)) | (1 << (SparkSqlParser.KW_LIKE - 131)) | (1 << (SparkSqlParser.KW_ILIKE - 131)) | (1 << (SparkSqlParser.KW_LIMIT - 131)))) !== 0) || ((((_la - 163)) & ~0x1F) === 0 && ((1 << (_la - 163)) & ((1 << (SparkSqlParser.KW_LINES - 163)) | (1 << (SparkSqlParser.KW_LIST - 163)) | (1 << (SparkSqlParser.KW_LOAD - 163)) | (1 << (SparkSqlParser.KW_LOCAL - 163)) | (1 << (SparkSqlParser.KW_LOCATION - 163)) | (1 << (SparkSqlParser.KW_LOCK - 163)) | (1 << (SparkSqlParser.KW_LOCKS - 163)) | (1 << (SparkSqlParser.KW_LOGICAL - 163)) | (1 << (SparkSqlParser.KW_LONG - 163)) | (1 << (SparkSqlParser.KW_MACRO - 163)) | (1 << (SparkSqlParser.KW_MAP - 163)) | (1 << (SparkSqlParser.KW_MATCHED - 163)) | (1 << (SparkSqlParser.KW_MERGE - 163)) | (1 << (SparkSqlParser.KW_MICROSECOND - 163)) | (1 << (SparkSqlParser.KW_MICROSECONDS - 163)) | (1 << (SparkSqlParser.KW_MILLISECOND - 163)) | (1 << (SparkSqlParser.KW_MILLISECONDS - 163)) | (1 << (SparkSqlParser.KW_MINUTE - 163)) | (1 << (SparkSqlParser.KW_MINUTES - 163)) | (1 << (SparkSqlParser.KW_MONTH - 163)) | (1 << (SparkSqlParser.KW_MONTHS - 163)) | (1 << (SparkSqlParser.KW_MSCK - 163)) | (1 << (SparkSqlParser.KW_NAME - 163)) | (1 << (SparkSqlParser.KW_NAMESPACE - 163)) | (1 << (SparkSqlParser.KW_NAMESPACES - 163)) | (1 << (SparkSqlParser.KW_NANOSECOND - 163)) | (1 << (SparkSqlParser.KW_NANOSECONDS - 163)) | (1 << (SparkSqlParser.KW_NO - 163)) | (1 << (SparkSqlParser.KW_NULLS - 163)))) !== 0) || ((((_la - 195)) & ~0x1F) === 0 && ((1 << (_la - 195)) & ((1 << (SparkSqlParser.KW_NUMERIC - 195)) | (1 << (SparkSqlParser.KW_OF - 195)) | (1 << (SparkSqlParser.KW_OPTION - 195)) | (1 << (SparkSqlParser.KW_OPTIONS - 195)) | (1 << (SparkSqlParser.KW_OUT - 195)) | (1 << (SparkSqlParser.KW_OUTPUTFORMAT - 195)) | (1 << (SparkSqlParser.KW_OVER - 195)) | (1 << (SparkSqlParser.KW_OVERLAY - 195)) | (1 << (SparkSqlParser.KW_OVERWRITE - 195)) | (1 << (SparkSqlParser.KW_PARTITION - 195)) | (1 << (SparkSqlParser.KW_PARTITIONED - 195)) | (1 << (SparkSqlParser.KW_PARTITIONS - 195)) | (1 << (SparkSqlParser.KW_PERCENTLIT - 195)) | (1 << (SparkSqlParser.KW_PIVOT - 195)) | (1 << (SparkSqlParser.KW_PLACING - 195)) | (1 << (SparkSqlParser.KW_POSITION - 195)) | (1 << (SparkSqlParser.KW_PRECEDING - 195)) | (1 << (SparkSqlParser.KW_PRINCIPALS - 195)) | (1 << (SparkSqlParser.KW_PROPERTIES - 195)) | (1 << (SparkSqlParser.KW_PURGE - 195)) | (1 << (SparkSqlParser.KW_QUARTER - 195)) | (1 << (SparkSqlParser.KW_QUERY - 195)))) !== 0) || ((((_la - 227)) & ~0x1F) === 0 && ((1 << (_la - 227)) & ((1 << (SparkSqlParser.KW_RANGE - 227)) | (1 << (SparkSqlParser.KW_REAL - 227)) | (1 << (SparkSqlParser.KW_RECORDREADER - 227)) | (1 << (SparkSqlParser.KW_RECORDWRITER - 227)) | (1 << (SparkSqlParser.KW_RECOVER - 227)) | (1 << (SparkSqlParser.KW_REDUCE - 227)) | (1 << (SparkSqlParser.KW_REFRESH - 227)) | (1 << (SparkSqlParser.KW_RENAME - 227)) | (1 << (SparkSqlParser.KW_REPAIR - 227)) | (1 << (SparkSqlParser.KW_REPEATABLE - 227)) | (1 << (SparkSqlParser.KW_REPLACE - 227)) | (1 << (SparkSqlParser.KW_RESET - 227)) | (1 << (SparkSqlParser.KW_RESPECT - 227)) | (1 << (SparkSqlParser.KW_RESTRICT - 227)) | (1 << (SparkSqlParser.KW_REVOKE - 227)) | (1 << (SparkSqlParser.KW_RLIKE - 227)) | (1 << (SparkSqlParser.KW_REGEXP - 227)) | (1 << (SparkSqlParser.KW_ROLE - 227)) | (1 << (SparkSqlParser.KW_ROLES - 227)) | (1 << (SparkSqlParser.KW_ROLLBACK - 227)) | (1 << (SparkSqlParser.KW_ROLLUP - 227)) | (1 << (SparkSqlParser.KW_ROW - 227)) | (1 << (SparkSqlParser.KW_ROWS - 227)) | (1 << (SparkSqlParser.KW_SECOND - 227)) | (1 << (SparkSqlParser.KW_SECONDS - 227)) | (1 << (SparkSqlParser.KW_SCHEMA - 227)) | (1 << (SparkSqlParser.KW_SCHEMAS - 227)) | (1 << (SparkSqlParser.KW_SEMI - 227)) | (1 << (SparkSqlParser.KW_SEPARATED - 227)))) !== 0) || ((((_la - 259)) & ~0x1F) === 0 && ((1 << (_la - 259)) & ((1 << (SparkSqlParser.KW_SERDE - 259)) | (1 << (SparkSqlParser.KW_SERDEPROPERTIES - 259)) | (1 << (SparkSqlParser.KW_SET - 259)) | (1 << (SparkSqlParser.KW_SETMINUS - 259)) | (1 << (SparkSqlParser.KW_SETS - 259)) | (1 << (SparkSqlParser.KW_SHORT - 259)) | (1 << (SparkSqlParser.KW_SHOW - 259)) | (1 << (SparkSqlParser.KW_SINGLE - 259)) | (1 << (SparkSqlParser.KW_SKEWED - 259)) | (1 << (SparkSqlParser.KW_SMALLINT - 259)) | (1 << (SparkSqlParser.KW_SORT - 259)) | (1 << (SparkSqlParser.KW_SORTED - 259)) | (1 << (SparkSqlParser.KW_SOURCE - 259)) | (1 << (SparkSqlParser.KW_START - 259)) | (1 << (SparkSqlParser.KW_STATISTICS - 259)) | (1 << (SparkSqlParser.KW_STORED - 259)) | (1 << (SparkSqlParser.KW_STRATIFY - 259)) | (1 << (SparkSqlParser.KW_STRING - 259)) | (1 << (SparkSqlParser.KW_STRUCT - 259)) | (1 << (SparkSqlParser.KW_SUBSTR - 259)) | (1 << (SparkSqlParser.KW_SUBSTRING - 259)) | (1 << (SparkSqlParser.KW_SYNC - 259)) | (1 << (SparkSqlParser.KW_SYSTEM - 259)) | (1 << (SparkSqlParser.KW_SYSTEM_TIME - 259)) | (1 << (SparkSqlParser.KW_SYSTEM_VERSION - 259)) | (1 << (SparkSqlParser.KW_TABLES - 259)) | (1 << (SparkSqlParser.KW_TABLESAMPLE - 259)) | (1 << (SparkSqlParser.KW_TARGET - 259)) | (1 << (SparkSqlParser.KW_TBLPROPERTIES - 259)))) !== 0) || ((((_la - 291)) & ~0x1F) === 0 && ((1 << (_la - 291)) & ((1 << (SparkSqlParser.KW_TEMPORARY - 291)) | (1 << (SparkSqlParser.KW_TERMINATED - 291)) | (1 << (SparkSqlParser.KW_TIMEDIFF - 291)) | (1 << (SparkSqlParser.KW_TIMESTAMP - 291)) | (1 << (SparkSqlParser.KW_TIMESTAMP_LTZ - 291)) | (1 << (SparkSqlParser.KW_TIMESTAMP_NTZ - 291)) | (1 << (SparkSqlParser.KW_TIMESTAMPADD - 291)) | (1 << (SparkSqlParser.KW_TIMESTAMPDIFF - 291)) | (1 << (SparkSqlParser.KW_TINYINT - 291)) | (1 << (SparkSqlParser.KW_TOUCH - 291)) | (1 << (SparkSqlParser.KW_TRANSACTION - 291)) | (1 << (SparkSqlParser.KW_TRANSACTIONS - 291)) | (1 << (SparkSqlParser.KW_TRANSFORM - 291)) | (1 << (SparkSqlParser.KW_TRIM - 291)) | (1 << (SparkSqlParser.KW_TRUE - 291)) | (1 << (SparkSqlParser.KW_TRUNCATE - 291)) | (1 << (SparkSqlParser.KW_TRY_CAST - 291)) | (1 << (SparkSqlParser.KW_TYPE - 291)) | (1 << (SparkSqlParser.KW_UNARCHIVE - 291)) | (1 << (SparkSqlParser.KW_UNBOUNDED - 291)) | (1 << (SparkSqlParser.KW_UNCACHE - 291)) | (1 << (SparkSqlParser.KW_UNLOCK - 291)) | (1 << (SparkSqlParser.KW_UNPIVOT - 291)) | (1 << (SparkSqlParser.KW_UNSET - 291)) | (1 << (SparkSqlParser.KW_UPDATE - 291)))) !== 0) || ((((_la - 323)) & ~0x1F) === 0 && ((1 << (_la - 323)) & ((1 << (SparkSqlParser.KW_USE - 323)) | (1 << (SparkSqlParser.KW_VALUES - 323)) | (1 << (SparkSqlParser.KW_VARCHAR - 323)) | (1 << (SparkSqlParser.KW_VAR - 323)) | (1 << (SparkSqlParser.KW_VARIABLE - 323)) | (1 << (SparkSqlParser.KW_VERSION - 323)) | (1 << (SparkSqlParser.KW_VIEW - 323)) | (1 << (SparkSqlParser.KW_VIEWS - 323)) | (1 << (SparkSqlParser.KW_VOID - 323)) | (1 << (SparkSqlParser.KW_WEEK - 323)) | (1 << (SparkSqlParser.KW_WEEKS - 323)) | (1 << (SparkSqlParser.KW_WINDOW - 323)) | (1 << (SparkSqlParser.KW_YEAR - 323)) | (1 << (SparkSqlParser.KW_YEARS - 323)) | (1 << (SparkSqlParser.KW_ZONE - 323)))) !== 0))) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public strictNonReserved(): StrictNonReservedContext { let _localctx: StrictNonReservedContext = new StrictNonReservedContext(this._ctx, this.state); this.enterRule(_localctx, 382, SparkSqlParser.RULE_strictNonReserved); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3819; _la = this._input.LA(1); if (!(_la === SparkSqlParser.KW_ANTI || _la === SparkSqlParser.KW_CROSS || _la === SparkSqlParser.KW_EXCEPT || _la === SparkSqlParser.KW_FULL || ((((_la - 142)) & ~0x1F) === 0 && ((1 << (_la - 142)) & ((1 << (SparkSqlParser.KW_INNER - 142)) | (1 << (SparkSqlParser.KW_INTERSECT - 142)) | (1 << (SparkSqlParser.KW_JOIN - 142)) | (1 << (SparkSqlParser.KW_LATERAL - 142)) | (1 << (SparkSqlParser.KW_LEFT - 142)))) !== 0) || _la === SparkSqlParser.KW_NATURAL || _la === SparkSqlParser.KW_ON || ((((_la - 243)) & ~0x1F) === 0 && ((1 << (_la - 243)) & ((1 << (SparkSqlParser.KW_RIGHT - 243)) | (1 << (SparkSqlParser.KW_SEMI - 243)) | (1 << (SparkSqlParser.KW_SETMINUS - 243)))) !== 0) || _la === SparkSqlParser.KW_UNION || _la === SparkSqlParser.KW_USING)) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } // @RuleVersion(0) public nonReserved(): NonReservedContext { let _localctx: NonReservedContext = new NonReservedContext(this._ctx, this.state); this.enterRule(_localctx, 384, SparkSqlParser.RULE_nonReserved); let _la: number; try { this.enterOuterAlt(_localctx, 1); { this.state = 3821; _la = this._input.LA(1); if (!((((_la) & ~0x1F) === 0 && ((1 << _la) & ((1 << SparkSqlParser.KW_ADD) | (1 << SparkSqlParser.KW_AFTER) | (1 << SparkSqlParser.KW_ALL) | (1 << SparkSqlParser.KW_ALTER) | (1 << SparkSqlParser.KW_ALWAYS) | (1 << SparkSqlParser.KW_ANALYZE) | (1 << SparkSqlParser.KW_AND) | (1 << SparkSqlParser.KW_ANY) | (1 << SparkSqlParser.KW_ANY_VALUE) | (1 << SparkSqlParser.KW_ARCHIVE) | (1 << SparkSqlParser.KW_ARRAY) | (1 << SparkSqlParser.KW_AS) | (1 << SparkSqlParser.KW_ASC) | (1 << SparkSqlParser.KW_AT) | (1 << SparkSqlParser.KW_AUTHORIZATION) | (1 << SparkSqlParser.KW_BETWEEN) | (1 << SparkSqlParser.KW_BIGINT) | (1 << SparkSqlParser.KW_BINARY) | (1 << SparkSqlParser.KW_BOOLEAN) | (1 << SparkSqlParser.KW_BOTH) | (1 << SparkSqlParser.KW_BUCKET) | (1 << SparkSqlParser.KW_BUCKETS) | (1 << SparkSqlParser.KW_BY))) !== 0) || ((((_la - 32)) & ~0x1F) === 0 && ((1 << (_la - 32)) & ((1 << (SparkSqlParser.KW_BYTE - 32)) | (1 << (SparkSqlParser.KW_CACHE - 32)) | (1 << (SparkSqlParser.KW_CASCADE - 32)) | (1 << (SparkSqlParser.KW_CASE - 32)) | (1 << (SparkSqlParser.KW_CAST - 32)) | (1 << (SparkSqlParser.KW_CATALOG - 32)) | (1 << (SparkSqlParser.KW_CATALOGS - 32)) | (1 << (SparkSqlParser.KW_CHANGE - 32)) | (1 << (SparkSqlParser.KW_CHAR - 32)) | (1 << (SparkSqlParser.KW_CHARACTER - 32)) | (1 << (SparkSqlParser.KW_CHECK - 32)) | (1 << (SparkSqlParser.KW_CLEAR - 32)) | (1 << (SparkSqlParser.KW_CLUSTER - 32)) | (1 << (SparkSqlParser.KW_CLUSTERED - 32)) | (1 << (SparkSqlParser.KW_CODEGEN - 32)) | (1 << (SparkSqlParser.KW_COLLATE - 32)) | (1 << (SparkSqlParser.KW_COLLECTION - 32)) | (1 << (SparkSqlParser.KW_COLUMN - 32)) | (1 << (SparkSqlParser.KW_COLUMNS - 32)) | (1 << (SparkSqlParser.KW_COMMENT - 32)) | (1 << (SparkSqlParser.KW_COMMIT - 32)) | (1 << (SparkSqlParser.KW_COMPACT - 32)) | (1 << (SparkSqlParser.KW_COMPACTIONS - 32)) | (1 << (SparkSqlParser.KW_COMPUTE - 32)) | (1 << (SparkSqlParser.KW_CONCATENATE - 32)) | (1 << (SparkSqlParser.KW_CONSTRAINT - 32)) | (1 << (SparkSqlParser.KW_COST - 32)) | (1 << (SparkSqlParser.KW_CREATE - 32)) | (1 << (SparkSqlParser.KW_CUBE - 32)) | (1 << (SparkSqlParser.KW_CURRENT - 32)) | (1 << (SparkSqlParser.KW_CURRENT_DATE - 32)))) !== 0) || ((((_la - 64)) & ~0x1F) === 0 && ((1 << (_la - 64)) & ((1 << (SparkSqlParser.KW_CURRENT_TIME - 64)) | (1 << (SparkSqlParser.KW_CURRENT_TIMESTAMP - 64)) | (1 << (SparkSqlParser.KW_CURRENT_USER - 64)) | (1 << (SparkSqlParser.KW_DAY - 64)) | (1 << (SparkSqlParser.KW_DAYS - 64)) | (1 << (SparkSqlParser.KW_DAYOFYEAR - 64)) | (1 << (SparkSqlParser.KW_DATA - 64)) | (1 << (SparkSqlParser.KW_DATE - 64)) | (1 << (SparkSqlParser.KW_DATABASE - 64)) | (1 << (SparkSqlParser.KW_DATABASES - 64)) | (1 << (SparkSqlParser.KW_DATEADD - 64)) | (1 << (SparkSqlParser.KW_DATE_ADD - 64)) | (1 << (SparkSqlParser.KW_DATEDIFF - 64)) | (1 << (SparkSqlParser.KW_DATE_DIFF - 64)) | (1 << (SparkSqlParser.KW_DBPROPERTIES - 64)) | (1 << (SparkSqlParser.KW_DEC - 64)) | (1 << (SparkSqlParser.KW_DECIMAL - 64)) | (1 << (SparkSqlParser.KW_DECLARE - 64)) | (1 << (SparkSqlParser.KW_DEFAULT - 64)) | (1 << (SparkSqlParser.KW_DEFINED - 64)) | (1 << (SparkSqlParser.KW_DELETE - 64)) | (1 << (SparkSqlParser.KW_DELIMITED - 64)) | (1 << (SparkSqlParser.KW_DESC - 64)) | (1 << (SparkSqlParser.KW_DESCRIBE - 64)) | (1 << (SparkSqlParser.KW_DFS - 64)) | (1 << (SparkSqlParser.KW_DIRECTORIES - 64)) | (1 << (SparkSqlParser.KW_DIRECTORY - 64)) | (1 << (SparkSqlParser.KW_DISTINCT - 64)) | (1 << (SparkSqlParser.KW_DISTRIBUTE - 64)) | (1 << (SparkSqlParser.KW_DIV - 64)) | (1 << (SparkSqlParser.KW_DOUBLE - 64)) | (1 << (SparkSqlParser.KW_DROP - 64)))) !== 0) || ((((_la - 96)) & ~0x1F) === 0 && ((1 << (_la - 96)) & ((1 << (SparkSqlParser.KW_ELSE - 96)) | (1 << (SparkSqlParser.KW_END - 96)) | (1 << (SparkSqlParser.KW_ESCAPE - 96)) | (1 << (SparkSqlParser.KW_ESCAPED - 96)) | (1 << (SparkSqlParser.KW_EXCHANGE - 96)) | (1 << (SparkSqlParser.KW_EXCLUDE - 96)) | (1 << (SparkSqlParser.KW_EXISTS - 96)) | (1 << (SparkSqlParser.KW_EXPLAIN - 96)) | (1 << (SparkSqlParser.KW_EXPORT - 96)) | (1 << (SparkSqlParser.KW_EXTENDED - 96)) | (1 << (SparkSqlParser.KW_EXTERNAL - 96)) | (1 << (SparkSqlParser.KW_EXTRACT - 96)) | (1 << (SparkSqlParser.KW_FALSE - 96)) | (1 << (SparkSqlParser.KW_FETCH - 96)) | (1 << (SparkSqlParser.KW_FIELDS - 96)) | (1 << (SparkSqlParser.KW_FILTER - 96)) | (1 << (SparkSqlParser.KW_FILEFORMAT - 96)) | (1 << (SparkSqlParser.KW_FIRST - 96)) | (1 << (SparkSqlParser.KW_FLOAT - 96)) | (1 << (SparkSqlParser.KW_FOLLOWING - 96)) | (1 << (SparkSqlParser.KW_FOR - 96)) | (1 << (SparkSqlParser.KW_FOREIGN - 96)) | (1 << (SparkSqlParser.KW_FORMAT - 96)) | (1 << (SparkSqlParser.KW_FORMATTED - 96)) | (1 << (SparkSqlParser.KW_FROM - 96)) | (1 << (SparkSqlParser.KW_FUNCTION - 96)) | (1 << (SparkSqlParser.KW_FUNCTIONS - 96)) | (1 << (SparkSqlParser.KW_GENERATED - 96)) | (1 << (SparkSqlParser.KW_GLOBAL - 96)) | (1 << (SparkSqlParser.KW_GRANT - 96)))) !== 0) || ((((_la - 128)) & ~0x1F) === 0 && ((1 << (_la - 128)) & ((1 << (SparkSqlParser.KW_GROUP - 128)) | (1 << (SparkSqlParser.KW_GROUPING - 128)) | (1 << (SparkSqlParser.KW_HAVING - 128)) | (1 << (SparkSqlParser.KW_BINARY_HEX - 128)) | (1 << (SparkSqlParser.KW_HOUR - 128)) | (1 << (SparkSqlParser.KW_HOURS - 128)) | (1 << (SparkSqlParser.KW_IDENTIFIER_KW - 128)) | (1 << (SparkSqlParser.KW_IF - 128)) | (1 << (SparkSqlParser.KW_IGNORE - 128)) | (1 << (SparkSqlParser.KW_IMPORT - 128)) | (1 << (SparkSqlParser.KW_IN - 128)) | (1 << (SparkSqlParser.KW_INCLUDE - 128)) | (1 << (SparkSqlParser.KW_INDEX - 128)) | (1 << (SparkSqlParser.KW_INDEXES - 128)) | (1 << (SparkSqlParser.KW_INPATH - 128)) | (1 << (SparkSqlParser.KW_INPUTFORMAT - 128)) | (1 << (SparkSqlParser.KW_INSERT - 128)) | (1 << (SparkSqlParser.KW_INTERVAL - 128)) | (1 << (SparkSqlParser.KW_INT - 128)) | (1 << (SparkSqlParser.KW_INTEGER - 128)) | (1 << (SparkSqlParser.KW_INTO - 128)) | (1 << (SparkSqlParser.KW_IS - 128)) | (1 << (SparkSqlParser.KW_ITEMS - 128)) | (1 << (SparkSqlParser.KW_KEYS - 128)) | (1 << (SparkSqlParser.KW_LAST - 128)) | (1 << (SparkSqlParser.KW_LAZY - 128)) | (1 << (SparkSqlParser.KW_LEADING - 128)))) !== 0) || ((((_la - 160)) & ~0x1F) === 0 && ((1 << (_la - 160)) & ((1 << (SparkSqlParser.KW_LIKE - 160)) | (1 << (SparkSqlParser.KW_ILIKE - 160)) | (1 << (SparkSqlParser.KW_LIMIT - 160)) | (1 << (SparkSqlParser.KW_LINES - 160)) | (1 << (SparkSqlParser.KW_LIST - 160)) | (1 << (SparkSqlParser.KW_LOAD - 160)) | (1 << (SparkSqlParser.KW_LOCAL - 160)) | (1 << (SparkSqlParser.KW_LOCATION - 160)) | (1 << (SparkSqlParser.KW_LOCK - 160)) | (1 << (SparkSqlParser.KW_LOCKS - 160)) | (1 << (SparkSqlParser.KW_LOGICAL - 160)) | (1 << (SparkSqlParser.KW_LONG - 160)) | (1 << (SparkSqlParser.KW_MACRO - 160)) | (1 << (SparkSqlParser.KW_MAP - 160)) | (1 << (SparkSqlParser.KW_MATCHED - 160)) | (1 << (SparkSqlParser.KW_MERGE - 160)) | (1 << (SparkSqlParser.KW_MICROSECOND - 160)) | (1 << (SparkSqlParser.KW_MICROSECONDS - 160)) | (1 << (SparkSqlParser.KW_MILLISECOND - 160)) | (1 << (SparkSqlParser.KW_MILLISECONDS - 160)) | (1 << (SparkSqlParser.KW_MINUTE - 160)) | (1 << (SparkSqlParser.KW_MINUTES - 160)) | (1 << (SparkSqlParser.KW_MONTH - 160)) | (1 << (SparkSqlParser.KW_MONTHS - 160)) | (1 << (SparkSqlParser.KW_MSCK - 160)) | (1 << (SparkSqlParser.KW_NAME - 160)) | (1 << (SparkSqlParser.KW_NAMESPACE - 160)) | (1 << (SparkSqlParser.KW_NAMESPACES - 160)) | (1 << (SparkSqlParser.KW_NANOSECOND - 160)) | (1 << (SparkSqlParser.KW_NANOSECONDS - 160)) | (1 << (SparkSqlParser.KW_NO - 160)))) !== 0) || ((((_la - 192)) & ~0x1F) === 0 && ((1 << (_la - 192)) & ((1 << (SparkSqlParser.KW_NOT - 192)) | (1 << (SparkSqlParser.KW_NULL - 192)) | (1 << (SparkSqlParser.KW_NULLS - 192)) | (1 << (SparkSqlParser.KW_NUMERIC - 192)) | (1 << (SparkSqlParser.KW_OF - 192)) | (1 << (SparkSqlParser.KW_OFFSET - 192)) | (1 << (SparkSqlParser.KW_ONLY - 192)) | (1 << (SparkSqlParser.KW_OPTION - 192)) | (1 << (SparkSqlParser.KW_OPTIONS - 192)) | (1 << (SparkSqlParser.KW_OR - 192)) | (1 << (SparkSqlParser.KW_ORDER - 192)) | (1 << (SparkSqlParser.KW_OUT - 192)) | (1 << (SparkSqlParser.KW_OUTER - 192)) | (1 << (SparkSqlParser.KW_OUTPUTFORMAT - 192)) | (1 << (SparkSqlParser.KW_OVER - 192)) | (1 << (SparkSqlParser.KW_OVERLAPS - 192)) | (1 << (SparkSqlParser.KW_OVERLAY - 192)) | (1 << (SparkSqlParser.KW_OVERWRITE - 192)) | (1 << (SparkSqlParser.KW_PARTITION - 192)) | (1 << (SparkSqlParser.KW_PARTITIONED - 192)) | (1 << (SparkSqlParser.KW_PARTITIONS - 192)) | (1 << (SparkSqlParser.KW_PERCENTILE_CONT - 192)) | (1 << (SparkSqlParser.KW_PERCENTILE_DISC - 192)) | (1 << (SparkSqlParser.KW_PERCENTLIT - 192)) | (1 << (SparkSqlParser.KW_PIVOT - 192)) | (1 << (SparkSqlParser.KW_PLACING - 192)) | (1 << (SparkSqlParser.KW_POSITION - 192)) | (1 << (SparkSqlParser.KW_PRECEDING - 192)) | (1 << (SparkSqlParser.KW_PRIMARY - 192)) | (1 << (SparkSqlParser.KW_PRINCIPALS - 192)) | (1 << (SparkSqlParser.KW_PROPERTIES - 192)))) !== 0) || ((((_la - 224)) & ~0x1F) === 0 && ((1 << (_la - 224)) & ((1 << (SparkSqlParser.KW_PURGE - 224)) | (1 << (SparkSqlParser.KW_QUARTER - 224)) | (1 << (SparkSqlParser.KW_QUERY - 224)) | (1 << (SparkSqlParser.KW_RANGE - 224)) | (1 << (SparkSqlParser.KW_REAL - 224)) | (1 << (SparkSqlParser.KW_RECORDREADER - 224)) | (1 << (SparkSqlParser.KW_RECORDWRITER - 224)) | (1 << (SparkSqlParser.KW_RECOVER - 224)) | (1 << (SparkSqlParser.KW_REDUCE - 224)) | (1 << (SparkSqlParser.KW_REFERENCES - 224)) | (1 << (SparkSqlParser.KW_REFRESH - 224)) | (1 << (SparkSqlParser.KW_RENAME - 224)) | (1 << (SparkSqlParser.KW_REPAIR - 224)) | (1 << (SparkSqlParser.KW_REPEATABLE - 224)) | (1 << (SparkSqlParser.KW_REPLACE - 224)) | (1 << (SparkSqlParser.KW_RESET - 224)) | (1 << (SparkSqlParser.KW_RESPECT - 224)) | (1 << (SparkSqlParser.KW_RESTRICT - 224)) | (1 << (SparkSqlParser.KW_REVOKE - 224)) | (1 << (SparkSqlParser.KW_RLIKE - 224)) | (1 << (SparkSqlParser.KW_REGEXP - 224)) | (1 << (SparkSqlParser.KW_ROLE - 224)) | (1 << (SparkSqlParser.KW_ROLES - 224)) | (1 << (SparkSqlParser.KW_ROLLBACK - 224)) | (1 << (SparkSqlParser.KW_ROLLUP - 224)) | (1 << (SparkSqlParser.KW_ROW - 224)) | (1 << (SparkSqlParser.KW_ROWS - 224)) | (1 << (SparkSqlParser.KW_SECOND - 224)) | (1 << (SparkSqlParser.KW_SECONDS - 224)) | (1 << (SparkSqlParser.KW_SCHEMA - 224)) | (1 << (SparkSqlParser.KW_SCHEMAS - 224)))) !== 0) || ((((_la - 256)) & ~0x1F) === 0 && ((1 << (_la - 256)) & ((1 << (SparkSqlParser.KW_SELECT - 256)) | (1 << (SparkSqlParser.KW_SEPARATED - 256)) | (1 << (SparkSqlParser.KW_SERDE - 256)) | (1 << (SparkSqlParser.KW_SERDEPROPERTIES - 256)) | (1 << (SparkSqlParser.KW_SESSION_USER - 256)) | (1 << (SparkSqlParser.KW_SET - 256)) | (1 << (SparkSqlParser.KW_SETS - 256)) | (1 << (SparkSqlParser.KW_SHORT - 256)) | (1 << (SparkSqlParser.KW_SHOW - 256)) | (1 << (SparkSqlParser.KW_SINGLE - 256)) | (1 << (SparkSqlParser.KW_SKEWED - 256)) | (1 << (SparkSqlParser.KW_SMALLINT - 256)) | (1 << (SparkSqlParser.KW_SOME - 256)) | (1 << (SparkSqlParser.KW_SORT - 256)) | (1 << (SparkSqlParser.KW_SORTED - 256)) | (1 << (SparkSqlParser.KW_SOURCE - 256)) | (1 << (SparkSqlParser.KW_START - 256)) | (1 << (SparkSqlParser.KW_STATISTICS - 256)) | (1 << (SparkSqlParser.KW_STORED - 256)) | (1 << (SparkSqlParser.KW_STRATIFY - 256)) | (1 << (SparkSqlParser.KW_STRING - 256)) | (1 << (SparkSqlParser.KW_STRUCT - 256)) | (1 << (SparkSqlParser.KW_SUBSTR - 256)) | (1 << (SparkSqlParser.KW_SUBSTRING - 256)) | (1 << (SparkSqlParser.KW_SYNC - 256)) | (1 << (SparkSqlParser.KW_SYSTEM - 256)) | (1 << (SparkSqlParser.KW_SYSTEM_TIME - 256)) | (1 << (SparkSqlParser.KW_SYSTEM_VERSION - 256)) | (1 << (SparkSqlParser.KW_TABLE - 256)) | (1 << (SparkSqlParser.KW_TABLES - 256)))) !== 0) || ((((_la - 288)) & ~0x1F) === 0 && ((1 << (_la - 288)) & ((1 << (SparkSqlParser.KW_TABLESAMPLE - 288)) | (1 << (SparkSqlParser.KW_TARGET - 288)) | (1 << (SparkSqlParser.KW_TBLPROPERTIES - 288)) | (1 << (SparkSqlParser.KW_TEMPORARY - 288)) | (1 << (SparkSqlParser.KW_TERMINATED - 288)) | (1 << (SparkSqlParser.KW_THEN - 288)) | (1 << (SparkSqlParser.KW_TIME - 288)) | (1 << (SparkSqlParser.KW_TIMEDIFF - 288)) | (1 << (SparkSqlParser.KW_TIMESTAMP - 288)) | (1 << (SparkSqlParser.KW_TIMESTAMP_LTZ - 288)) | (1 << (SparkSqlParser.KW_TIMESTAMP_NTZ - 288)) | (1 << (SparkSqlParser.KW_TIMESTAMPADD - 288)) | (1 << (SparkSqlParser.KW_TIMESTAMPDIFF - 288)) | (1 << (SparkSqlParser.KW_TINYINT - 288)) | (1 << (SparkSqlParser.KW_TO - 288)) | (1 << (SparkSqlParser.KW_TOUCH - 288)) | (1 << (SparkSqlParser.KW_TRAILING - 288)) | (1 << (SparkSqlParser.KW_TRANSACTION - 288)) | (1 << (SparkSqlParser.KW_TRANSACTIONS - 288)) | (1 << (SparkSqlParser.KW_TRANSFORM - 288)) | (1 << (SparkSqlParser.KW_TRIM - 288)) | (1 << (SparkSqlParser.KW_TRUE - 288)) | (1 << (SparkSqlParser.KW_TRUNCATE - 288)) | (1 << (SparkSqlParser.KW_TRY_CAST - 288)) | (1 << (SparkSqlParser.KW_TYPE - 288)) | (1 << (SparkSqlParser.KW_UNARCHIVE - 288)) | (1 << (SparkSqlParser.KW_UNBOUNDED - 288)) | (1 << (SparkSqlParser.KW_UNCACHE - 288)) | (1 << (SparkSqlParser.KW_UNIQUE - 288)) | (1 << (SparkSqlParser.KW_UNKNOWN - 288)) | (1 << (SparkSqlParser.KW_UNLOCK - 288)))) !== 0) || ((((_la - 320)) & ~0x1F) === 0 && ((1 << (_la - 320)) & ((1 << (SparkSqlParser.KW_UNPIVOT - 320)) | (1 << (SparkSqlParser.KW_UNSET - 320)) | (1 << (SparkSqlParser.KW_UPDATE - 320)) | (1 << (SparkSqlParser.KW_USE - 320)) | (1 << (SparkSqlParser.KW_USER - 320)) | (1 << (SparkSqlParser.KW_VALUES - 320)) | (1 << (SparkSqlParser.KW_VARCHAR - 320)) | (1 << (SparkSqlParser.KW_VAR - 320)) | (1 << (SparkSqlParser.KW_VARIABLE - 320)) | (1 << (SparkSqlParser.KW_VERSION - 320)) | (1 << (SparkSqlParser.KW_VIEW - 320)) | (1 << (SparkSqlParser.KW_VIEWS - 320)) | (1 << (SparkSqlParser.KW_VOID - 320)) | (1 << (SparkSqlParser.KW_WEEK - 320)) | (1 << (SparkSqlParser.KW_WEEKS - 320)) | (1 << (SparkSqlParser.KW_WHEN - 320)) | (1 << (SparkSqlParser.KW_WHERE - 320)) | (1 << (SparkSqlParser.KW_WINDOW - 320)) | (1 << (SparkSqlParser.KW_WITH - 320)) | (1 << (SparkSqlParser.KW_WITHIN - 320)) | (1 << (SparkSqlParser.KW_YEAR - 320)) | (1 << (SparkSqlParser.KW_YEARS - 320)) | (1 << (SparkSqlParser.KW_ZONE - 320)))) !== 0))) { this._errHandler.recoverInline(this); } else { if (this._input.LA(1) === Token.EOF) { this.matchedEOF = true; } this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { _localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return _localctx; } public sempred(_localctx: RuleContext, ruleIndex: number, predIndex: number): boolean { switch (ruleIndex) { case 48: return this.queryTerm_sempred(_localctx as QueryTermContext, predIndex); case 134: return this.booleanExpression_sempred(_localctx as BooleanExpressionContext, predIndex); case 136: return this.valueExpression_sempred(_localctx as ValueExpressionContext, predIndex); case 138: return this.primaryExpression_sempred(_localctx as PrimaryExpressionContext, predIndex); case 181: return this.identifier_sempred(_localctx as IdentifierContext, predIndex); case 182: return this.strictIdentifier_sempred(_localctx as StrictIdentifierContext, predIndex); case 183: return this.quotedIdentifier_sempred(_localctx as QuotedIdentifierContext, predIndex); case 185: return this.number_sempred(_localctx as NumberContext, predIndex); case 187: return this.stringLit_sempred(_localctx as StringLitContext, predIndex); } return true; } private queryTerm_sempred(_localctx: QueryTermContext, predIndex: number): boolean { switch (predIndex) { case 0: return this.precpred(this._ctx, 3); case 1: return this.legacy_setops_precedence_enabled; case 2: return this.precpred(this._ctx, 2); case 3: return !this.legacy_setops_precedence_enabled; case 4: return this.precpred(this._ctx, 1); case 5: return !this.legacy_setops_precedence_enabled; } return true; } private booleanExpression_sempred(_localctx: BooleanExpressionContext, predIndex: number): boolean { switch (predIndex) { case 6: return this.precpred(this._ctx, 2); case 7: return this.precpred(this._ctx, 1); } return true; } private valueExpression_sempred(_localctx: ValueExpressionContext, predIndex: number): boolean { switch (predIndex) { case 8: return this.precpred(this._ctx, 6); case 9: return this.precpred(this._ctx, 5); case 10: return this.precpred(this._ctx, 4); case 11: return this.precpred(this._ctx, 3); case 12: return this.precpred(this._ctx, 2); case 13: return this.precpred(this._ctx, 1); } return true; } private primaryExpression_sempred(_localctx: PrimaryExpressionContext, predIndex: number): boolean { switch (predIndex) { case 14: return this.precpred(this._ctx, 9); case 15: return this.precpred(this._ctx, 7); } return true; } private identifier_sempred(_localctx: IdentifierContext, predIndex: number): boolean { switch (predIndex) { case 16: return !this.SQL_standard_keyword_behavior; } return true; } private strictIdentifier_sempred(_localctx: StrictIdentifierContext, predIndex: number): boolean { switch (predIndex) { case 17: return this.SQL_standard_keyword_behavior; case 18: return !this.SQL_standard_keyword_behavior; } return true; } private quotedIdentifier_sempred(_localctx: QuotedIdentifierContext, predIndex: number): boolean { switch (predIndex) { case 19: return this.double_quoted_identifiers; } return true; } private number_sempred(_localctx: NumberContext, predIndex: number): boolean { switch (predIndex) { case 20: return !this.legacy_exponent_literal_as_decimal_enabled; case 21: return !this.legacy_exponent_literal_as_decimal_enabled; case 22: return this.legacy_exponent_literal_as_decimal_enabled; } return true; } private stringLit_sempred(_localctx: StringLitContext, predIndex: number): boolean { switch (predIndex) { case 23: return !this.double_quoted_identifiers; } return true; } private static readonly _serializedATNSegments: number = 8; private static readonly _serializedATNSegment0: string = "\x03\uC91D\uCABA\u058D\uAFBA\u4F53\u0607\uEA8B\uC241\x03\u0183\u0EF2\x04" + "\x02\t\x02\x04\x03\t\x03\x04\x04\t\x04\x04\x05\t\x05\x04\x06\t\x06\x04" + "\x07\t\x07\x04\b\t\b\x04\t\t\t\x04\n\t\n\x04\v\t\v\x04\f\t\f\x04\r\t\r" + "\x04\x0E\t\x0E\x04\x0F\t\x0F\x04\x10\t\x10\x04\x11\t\x11\x04\x12\t\x12" + "\x04\x13\t\x13\x04\x14\t\x14\x04\x15\t\x15\x04\x16\t\x16\x04\x17\t\x17" + "\x04\x18\t\x18\x04\x19\t\x19\x04\x1A\t\x1A\x04\x1B\t\x1B\x04\x1C\t\x1C" + "\x04\x1D\t\x1D\x04\x1E\t\x1E\x04\x1F\t\x1F\x04 \t \x04!\t!\x04\"\t\"\x04" + "#\t#\x04$\t$\x04%\t%\x04&\t&\x04\'\t\'\x04(\t(\x04)\t)\x04*\t*\x04+\t" + "+\x04,\t,\x04-\t-\x04.\t.\x04/\t/\x040\t0\x041\t1\x042\t2\x043\t3\x04" + "4\t4\x045\t5\x046\t6\x047\t7\x048\t8\x049\t9\x04:\t:\x04;\t;\x04<\t<\x04" + "=\t=\x04>\t>\x04?\t?\x04@\t@\x04A\tA\x04B\tB\x04C\tC\x04D\tD\x04E\tE\x04" + "F\tF\x04G\tG\x04H\tH\x04I\tI\x04J\tJ\x04K\tK\x04L\tL\x04M\tM\x04N\tN\x04" + "O\tO\x04P\tP\x04Q\tQ\x04R\tR\x04S\tS\x04T\tT\x04U\tU\x04V\tV\x04W\tW\x04" + "X\tX\x04Y\tY\x04Z\tZ\x04[\t[\x04\\\t\\\x04]\t]\x04^\t^\x04_\t_\x04`\t" + "`\x04a\ta\x04b\tb\x04c\tc\x04d\td\x04e\te\x04f\tf\x04g\tg\x04h\th\x04" + "i\ti\x04j\tj\x04k\tk\x04l\tl\x04m\tm\x04n\tn\x04o\to\x04p\tp\x04q\tq\x04" + "r\tr\x04s\ts\x04t\tt\x04u\tu\x04v\tv\x04w\tw\x04x\tx\x04y\ty\x04z\tz\x04" + "{\t{\x04|\t|\x04}\t}\x04~\t~\x04\x7F\t\x7F\x04\x80\t\x80\x04\x81\t\x81" + "\x04\x82\t\x82\x04\x83\t\x83\x04\x84\t\x84\x04\x85\t\x85\x04\x86\t\x86" + "\x04\x87\t\x87\x04\x88\t\x88\x04\x89\t\x89\x04\x8A\t\x8A\x04\x8B\t\x8B" + "\x04\x8C\t\x8C\x04\x8D\t\x8D\x04\x8E\t\x8E\x04\x8F\t\x8F\x04\x90\t\x90" + "\x04\x91\t\x91\x04\x92\t\x92\x04\x93\t\x93\x04\x94\t\x94\x04\x95\t\x95" + "\x04\x96\t\x96\x04\x97\t\x97\x04\x98\t\x98\x04\x99\t\x99\x04\x9A\t\x9A" + "\x04\x9B\t\x9B\x04\x9C\t\x9C\x04\x9D\t\x9D\x04\x9E\t\x9E\x04\x9F\t\x9F" + "\x04\xA0\t\xA0\x04\xA1\t\xA1\x04\xA2\t\xA2\x04\xA3\t\xA3\x04\xA4\t\xA4" + "\x04\xA5\t\xA5\x04\xA6\t\xA6\x04\xA7\t\xA7\x04\xA8\t\xA8\x04\xA9\t\xA9" + "\x04\xAA\t\xAA\x04\xAB\t\xAB\x04\xAC\t\xAC\x04\xAD\t\xAD\x04\xAE\t\xAE" + "\x04\xAF\t\xAF\x04\xB0\t\xB0\x04\xB1\t\xB1\x04\xB2\t\xB2\x04\xB3\t\xB3" + "\x04\xB4\t\xB4\x04\xB5\t\xB5\x04\xB6\t\xB6\x04\xB7\t\xB7\x04\xB8\t\xB8" + "\x04\xB9\t\xB9\x04\xBA\t\xBA\x04\xBB\t\xBB\x04\xBC\t\xBC\x04\xBD\t\xBD" + "\x04\xBE\t\xBE\x04\xBF\t\xBF\x04\xC0\t\xC0\x04\xC1\t\xC1\x04\xC2\t\xC2" + "\x03\x02\x07\x02\u0186\n\x02\f\x02\x0E\x02\u0189\v\x02\x03\x02\x03\x02" + "\x03\x03\x03\x03\x05\x03\u018F\n\x03\x03\x04\x03\x04\x05\x04\u0193\n\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x05\x04\u01A0\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u01A5" + "\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x07\x04\u01AD\n" + "\x04\f\x04\x0E\x04\u01B0\v\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x05\x04\u01C2\n\x04\x03\x04\x03\x04\x05\x04\u01C6\n\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u01CC\n\x04\x03\x04\x05\x04\u01CF" + "\n\x04\x03\x04\x05\x04\u01D2\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03" + "\x04\x05\x04\u01D9\n\x04\x03\x04\x05\x04\u01DC\n\x04\x03\x04\x03\x04\x05" + "\x04\u01E0\n\x04\x03\x04\x05\x04\u01E3\n\x04\x03\x04\x03\x04\x03\x04\x05" + "\x04\u01E8\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x07\x04\u01F3\n\x04\f\x04\x0E\x04\u01F6\v\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u01FD\n\x04\x03\x04\x05\x04\u0200" + "\n\x04\x03\x04\x03\x04\x05\x04\u0204\n\x04\x03\x04\x05\x04\u0207\n\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u020D\n\x04\x03\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0218\n\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u021E\n\x04\x03\x04\x03\x04\x03" + "\x04\x05\x04\u0223\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0244" + "\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x05\x04\u0250\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x05\x04\u0259\n\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0264\n\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u026F" + "\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0274\n\x04\x03\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u027D\n\x04\x03\x04\x03\x04" + "\x05\x04\u0281\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0287\n\x04" + "\x03\x04\x03\x04\x05\x04\u028B\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0290" + "\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0296\n\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05" + "\x04\u02A2\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04" + "\u02AA\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u02B0\n\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04" + "\u02BB\n\x04\x03\x04\x03\x04\x05\x04\u02BF\n\x04\x03\x04\x06\x04\u02C2" + "\n\x04\r\x04\x0E\x04\u02C3\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u02D3" + "\n\x04\x03\x04\x03\x04\x05\x04\u02D7\n\x04\x03\x04\x03\x04\x03\x04\x07" + "\x04\u02DC\n\x04\f\x04\x0E\x04\u02DF\v\x04\x03\x04\x05\x04\u02E2\n\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u02E8\n\x04\x03\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03" + "\x04\x05\x04\u02F6\n\x04\x03\x04\x03\x04\x05\x04\u02FA\n\x04\x03\x04\x03" + "\x04\x03\x04\x05\x04\u02FF\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04" + "\u0305\n\x04\x03\x04\x05\x04\u0308\n\x04\x03\x04\x05\x04\u030B\n\x04\x03" + "\x04\x03\x04\x05\x04\u030F\n\x04\x03\x04\x03\x04\x05\x04\u0313\n\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x07\x04\u031B\n\x04\f\x04" + "\x0E\x04\u031E\v\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05" + "\x04\u0326\n\x04\x03\x04\x05\x04\u0329\n\x04\x03\x04\x03\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0332\n\x04\x03\x04\x03\x04\x03\x04" + "\x05\x04\u0337\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u033D\n\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0344\n\x04\x03\x04\x05" + "\x04\u0347\n\x04\x03\x04\x03\x04\x05\x04\u034B\n\x04\x03\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x03\x04\x07\x04\u0354\n\x04\f\x04\x0E\x04" + "\u0357\v\x04\x05\x04\u0359\n\x04\x03\x04\x03\x04\x05\x04\u035D\n\x04\x03" + "\x04\x03\x04\x05\x04\u0361\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04" + "\u0367\n\x04\x03\x04\x05\x04\u036A\n\x04\x03\x04\x03\x04\x05\x04\u036E" + "\n\x04\x03\x04\x05\x04\u0371\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05" + "\x04\u0377\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u037C\n\x04\x03\x04\x03" + "\x04\x05\x04\u0380\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04" + "\u0387\n\x04\x03\x04\x05\x04\u038A\n\x04\x03\x04\x05\x04\u038D\n\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0394\n\x04\x03\x04\x03\x04" + "\x03\x04\x05\x04\u0399\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03" + "\x04\x03\x04\x05\x04\u03A2\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x05\x04\u03AA\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u03B0" + "\n\x04\x03\x04\x05\x04\u03B3\n\x04\x03\x04\x05\x04\u03B6\n\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x05\x04\u03BC\n\x04\x03\x04\x03\x04\x05\x04\u03C0" + "\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u03C5\n\x04\x03\x04\x05\x04\u03C8" + "\n\x04\x03\x04\x03\x04\x05\x04\u03CC\n\x04\x05\x04\u03CE\n\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u03D6\n\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u03DE\n\x04\x03\x04\x05\x04" + "\u03E1\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u03E6\n\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x05\x04\u03EC\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u03F1" + "\n\x04\x03\x04\x05\x04\u03F4\n\x04\x03\x04\x03\x04\x05\x04\u03F8\n\x04" + "\x03\x04\x05\x04\u03FB\n\x04\x03\x04\x03\x04\x05\x04\u03FF\n\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x07\x04\u0419\n\x04\f\x04\x0E" + "\x04\u041C\v\x04\x05\x04\u041E\n\x04\x03\x04\x03\x04\x05\x04\u0422\n\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0428\n\x04\x03\x04\x05\x04\u042B" + "\n\x04\x03\x04\x05\x04\u042E\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0433" + "\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u043B\n" + "\x04\x03\x04\x03\x04\x03\x04\x05\x04\u0440\n\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x05\x04\u0446\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x05\x04\u044C" + "\n\x04\x03\x04\x05\x04\u044F\n\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03" + "\x04\x05\x04\u0456\n\x04\x03\x04\x03\x04\x03\x04\x07\x04\u045B\n\x04\f" + "\x04\x0E\x04\u045E\v\x04\x03\x04\x03\x04\x03\x04\x07\x04\u0463\n\x04\f" + "\x04\x0E\x04\u0466\v\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x07\x04\u0474\n\x04\f" + "\x04\x0E\x04\u0477\v\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x03\x04\x07\x04\u048F" + "\n\x04\f\x04\x0E\x04\u0492\v\x04\x05\x04\u0494\n\x04\x03\x04\x03\x04\x07" + "\x04\u0498\n\x04\f\x04\x0E\x04\u049B\v\x04\x03\x04\x03\x04\x03\x04\x03" + "\x04\x07\x04\u04A1\n\x04\f\x04\x0E\x04\u04A4\v\x04\x03\x04\x03\x04\x03" + "\x04\x03\x04\x07\x04\u04AA\n\x04\f\x04\x0E\x04\u04AD\v\x04\x03\x04\x03" + "\x04\x03\x04\x05\x04\u04B2\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u04B7" + "\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u04BC\n\x04\x03\x04\x03\x04\x03" + "\x04\x03\x04\x03\x04\x05\x04\u04C3\n\x04\x03\x04\x03\x04\x03\x04\x05\x04" + "\u04C8\n\x04\x03\x04\x03\x04\x03\x04\x05\x04\u04CD\n\x04\x03\x04\x03\x04" + "\x03\x04\x03\x04\x07\x04\u04D3\n\x04\f\x04\x0E\x04\u04D6\v\x04\x05\x04" + "\u04D8\n\x04\x03\x05\x03\x05\x05\x05\u04DC\n\x05\x03\x06\x03\x06\x03\x07" + "\x03\x07\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x05\b\u04E8\n\b\x03\b\x03" + "\b\x05\b\u04EC\n\b\x03\b\x03\b\x03\b\x03\b\x03\b\x05\b\u04F3\n\b\x03\b" + "\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03" + "\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03" + "\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03" + "\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03" + "\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03" + "\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03" + "\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03" + "\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03" + "\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03" + "\b\x03\b\x03\b\x03\b\x03\b\x03\b\x05\b\u0567\n\b\x03\b\x03\b\x03\b\x03" + "\b\x03\b\x03\b\x05\b\u056F\n\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x05" + "\b\u0577\n\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x05\b\u0580\n\b" + "\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x03\b\x05\b\u058A\n\b\x03\t" + "\x03\t\x05\t\u058E\n\t\x03\t\x05\t\u0591\n\t\x03\t\x03\t\x05\t\u0595\n" + "\t\x03\t\x03\t\x03\n\x03\n\x05\n\u059B\n\n\x03\n\x03\n\x03\n\x03\n\x03" + "\v\x03\v\x03\v\x03\v\x03\v\x03\v\x05\v\u05A7\n\v\x03\v\x03\v\x03\v\x03" + "\v\x03\f\x03\f\x03\f\x03\f\x03\f\x03\f\x05\f\u05B3\n\f\x03\f\x03\f\x03" + "\f\x05\f\u05B8\n\f\x03\r\x03\r\x03\r\x03\x0E\x03\x0E\x03\x0E\x03\x0F\x05" + "\x0F\u05C1\n\x0F\x03\x0F\x03\x0F\x03\x0F\x03\x10\x03\x10\x03\x10\x05\x10" + "\u05C9\n\x10\x03\x10\x03\x10\x03\x10\x05\x10\u05CE\n\x10\x05\x10\u05D0" + "\n\x10\x03\x10\x03\x10\x03\x10\x05\x10\u05D5\n\x10\x03\x10\x03\x10\x03" + "\x10\x05\x10\u05DA\n\x10\x03\x10\x03\x10\x05\x10\u05DE\n\x10\x03\x10\x05" + "\x10\u05E1\n\x10\x03\x10\x03\x10\x03\x10\x05\x10\u05E6\n\x10\x03\x10\x03" + "\x10\x03\x10\x05\x10\u05EB\n\x10\x03\x10\x03\x10\x03\x10\x03\x10\x03\x10" + "\x03\x10\x03\x10\x05\x10\u05F4\n\x10\x03\x10\x03\x10\x03\x10\x05\x10\u05F9" + "\n\x10\x03\x10\x05\x10\u05FC\n\x10\x03\x10\x03\x10\x03\x10\x05\x10\u0601" + "\n\x10\x03\x10\x03\x10\x05\x10\u0605\n\x10\x03\x10\x03\x10\x03\x10\x05" + "\x10\u060A\n\x10\x05\x10\u060C\n\x10\x03\x11\x03\x11\x05\x11\u0610\n\x11" + "\x03\x12\x03\x12\x03\x12\x03\x12\x03\x12\x07\x12\u0617\n\x12\f\x12\x0E" + "\x12\u061A\v\x12\x03\x12\x03\x12\x03\x13\x03\x13\x03\x13\x05\x13\u0621" + "\n\x13\x03\x13\x03\x13\x03\x13\x03\x13\x05\x13\u0627\n\x13\x03\x14\x03" + "\x14\x03\x15\x03\x15\x03\x16\x03\x16\x03\x16\x03\x16\x03\x16\x05\x16\u0632" + "\n\x16\x03\x17\x03\x17\x03\x17\x07\x17\u0637\n\x17\f\x17\x0E\x17\u063A" + "\v\x17\x03\x18\x03\x18\x03\x18\x03\x18\x07\x18\u0640\n\x18\f\x18\x0E\x18" + "\u0643\v\x18\x03\x19\x03\x19\x05\x19\u0647\n\x19\x03\x19\x05\x19\u064A" + "\n\x19\x03\x19\x03\x19\x03\x19\x03\x19\x03\x1A\x03\x1A\x03\x1A\x03\x1B" + "\x03\x1B\x03\x1B\x03\x1B\x03\x1B\x03\x1B\x03\x1B\x03\x1B\x03\x1B\x03\x1B" + "\x03\x1B\x03\x1B\x03\x1B\x07\x1B\u0660\n\x1B\f\x1B\x0E\x1B\u0663\v\x1B" + "\x03\x1C\x03\x1C\x03\x1C\x03\x1C\x07\x1C\u0669\n\x1C\f\x1C\x0E\x1C\u066C" + "\v\x1C\x03\x1C\x03\x1C\x03\x1D\x03\x1D\x05\x1D\u0672\n\x1D\x03\x1D\x05" + "\x1D\u0675\n\x1D\x03\x1E\x03\x1E\x03\x1E\x07\x1E\u067A\n\x1E\f\x1E\x0E" + "\x1E\u067D\v\x1E\x03\x1E\x05\x1E\u0680\n\x1E\x03\x1F\x03\x1F\x03\x1F\x03" + "\x1F\x05\x1F\u0686\n\x1F\x03 \x03 \x03 \x03 \x07 \u068C\n \f \x0E \u068F" + "\v \x03 \x03 \x03!\x03!\x05!\u0695\n!\x03!\x05!\u0698\n!\x03\"\x03\"\x03" + "\"\x03\"\x07\"\u069E\n\"\f\"\x0E\"\u06A1\v\"\x03\"\x03\"\x03#\x03#\x03" + "#\x03#\x07#\u06A9\n#\f#\x0E#\u06AC\v#\x03#\x03#\x03$\x03$\x03$\x03$\x03" + "$\x03$\x05$\u06B6\n$\x03%\x03%\x03%\x03%\x03%\x03%\x05%\u06BE\n%\x03&" + "\x03&\x03&\x03&\x05&\u06C4\n&\x03\'\x03\'\x03\'\x03(\x03(\x03(\x03(\x03" + "(\x06(\u06CE\n(\r(\x0E(\u06CF\x03(\x03(\x03(\x03(\x03(\x05(\u06D7\n(\x03" + "(\x03(\x03(\x03(\x03(\x05(\u06DE\n(\x03(\x03(\x03(\x03(\x03(\x03(\x03" + "(\x03(\x03(\x03(\x05(\u06EA\n(\x03(\x03(\x03(\x03(\x07(\u06F0\n(\f(\x0E" + "(\u06F3\v(\x03(\x07(\u06F6\n(\f(\x0E(\u06F9\v(\x03(\x07(\u06FC\n(\f(\x0E" + "(\u06FF\v(\x05(\u0701\n(\x03)\x03)\x03*\x03*\x03+\x03+\x03,\x03,\x03-" + "\x03-\x03.\x03.\x03/\x03/\x03/\x03/\x03/\x03/\x05/\u0715\n/\x030\x030" + "\x030\x030\x030\x070\u071C\n0\f0\x0E0\u071F\v0\x050\u0721\n0\x030\x03" + "0\x030\x030\x030\x070\u0728\n0\f0\x0E0\u072B\v0\x050\u072D\n0\x030\x03" + "0\x030\x030\x030\x070\u0734\n0\f0\x0E0\u0737\v0\x050\u0739\n0\x030\x03" + "0\x030\x030\x030\x070\u0740\n0\f0\x0E0\u0743\v0\x050\u0745\n0\x030\x05" + "0\u0748\n0\x030\x030\x030\x050\u074D\n0\x050\u074F\n0\x030\x030\x050\u0753" + "\n0\x031\x031\x031\x032\x032\x032\x032\x032\x032\x032\x052\u075F\n2\x03" + "2\x032\x032\x032\x032\x052\u0766\n2\x032\x032\x032\x032\x032\x052\u076D" + "\n2\x032\x072\u0770\n2\f2\x0E2\u0773\v2\x033\x033\x033\x033\x033\x033" + "\x033\x033\x033\x053\u077E\n3\x034\x034\x054\u0782\n4\x034\x034\x054\u0786" + "\n4\x035\x035\x065\u078A\n5\r5\x0E5\u078B\x036\x036\x056\u0790\n6\x03" + "6\x036\x036\x036\x076\u0796\n6\f6\x0E6\u0799\v6\x036\x056\u079C\n6\x03" + "6\x056\u079F\n6\x036\x056\u07A2\n6\x036\x056\u07A5\n6\x036\x036\x056\u07A9" + "\n6\x037\x037\x057\u07AD\n7\x037\x077\u07B0\n7\f7\x0E7\u07B3\v7\x037\x05" + "7\u07B6\n7\x037\x057\u07B9\n7\x037\x057\u07BC\n7\x037\x057\u07BF\n7\x03" + "7\x037\x057\u07C3\n7\x037\x077\u07C6\n7\f7\x0E7\u07C9\v7\x037\x057\u07CC" + "\n7\x037\x057\u07CF\n7\x037\x057\u07D2\n7\x037\x057\u07D5\n7\x057\u07D7" + "\n7\x038\x038\x038\x038\x058\u07DD\n8\x038\x038\x038\x038\x038\x058\u07E4" + "\n8\x038\x038\x038\x058\u07E9\n8\x038\x058\u07EC\n8\x038\x058\u07EF\n" + "8\x038\x038\x058\u07F3\n8\x038\x038\x038\x038\x038\x038\x038\x038\x05" + "8\u07FD\n8\x038\x038\x058\u0801\n8\x058\u0803\n8\x038\x058\u0806\n8\x03" + "8\x038\x058\u080A\n8\x039\x039\x079\u080E\n9\f9\x0E9\u0811\v9\x039\x05" + "9\u0814\n9\x039\x039\x03:\x03:\x03:\x03;\x03;\x03;\x03;\x05;\u081F\n;" + "\x03;\x03;\x03;\x03<\x03<\x03<\x03<\x03<\x05<\u0829\n<\x03<\x03<\x05<" + "\u082D\n<\x03<\x03<\x03<\x03=\x03=\x03=\x03=\x03=\x03=\x03=\x05=\u0839" + "\n=\x03=\x03=\x03=\x03>\x03>\x03>\x03>\x03>\x03>\x03>\x05>\u0845\n>\x03" + "?\x03?\x03?\x03?\x03?\x03?\x03?\x03?\x03?\x03?\x03?\x07?\u0852\n?\f?\x0E" + "?\u0855\v?\x03?\x03?\x05?\u0859\n?\x03@\x03@\x03@\x03@\x05@\u085F\n@\x03" + "A\x03A\x03A\x07A\u0864\nA\fA\x0EA\u0867\vA\x03B\x03B\x03B\x03B\x03C\x03" + "C\x03C\x03D\x03D\x03D\x03E\x03E\x03E\x05E\u0876\nE\x03E\x07E\u0879\nE" + "\fE\x0EE\u087C\vE\x03E\x03E\x03F\x03F\x03F\x03F\x03F\x03F\x07F\u0886\n" + "F\fF\x0EF\u0889\vF\x03F\x03F\x05F\u088D\nF\x03G\x03G\x03G\x03G\x07G\u0893" + "\nG\fG\x0EG\u0896\vG\x03G\x07G\u0899\nG\fG\x0EG\u089C\vG\x03G\x05G\u089F" + "\nG\x03G\x05G\u08A2\nG\x03H\x03H\x03I\x05I\u08A7\nI\x03I\x03I\x03I\x03" + "I\x03I\x05I\u08AE\nI\x03I\x03I\x03I\x03I\x05I\u08B4\nI\x03J\x03J\x03J" + "\x03J\x03J\x07J\u08BB\nJ\fJ\x0EJ\u08BE\vJ\x03J\x03J\x03J\x03J\x03J\x07" + "J\u08C5\nJ\fJ\x0EJ\u08C8\vJ\x03J\x03J\x03J\x03J\x03J\x03J\x03J\x03J\x03" + "J\x03J\x07J\u08D4\nJ\fJ\x0EJ\u08D7\vJ\x03J\x03J\x05J\u08DB\nJ\x05J\u08DD" + "\nJ\x03K\x03K\x05K\u08E1\nK\x03L\x03L\x03L\x03L\x03L\x07L\u08E8\nL\fL" + "\x0EL\u08EB\vL\x03L\x03L\x03L\x03L\x03L\x03L\x03L\x03L\x07L\u08F5\nL\f" + "L\x0EL\u08F8\vL\x03L\x03L\x05L\u08FC\nL\x03M\x03M\x05M\u0900\nM\x03N\x03" + "N\x03N\x03N\x07N\u0906\nN\fN\x0EN\u0909\vN\x05N\u090B\nN\x03N\x03N\x05" + "N\u090F\nN\x03O\x03O\x03O\x03O\x03O\x03O\x03O\x03O\x03O"; private static readonly _serializedATNSegment1: string = "\x03O\x07O\u091B\nO\fO\x0EO\u091E\vO\x03O\x03O\x03O\x03P\x03P\x03P\x03" + "P\x03P\x07P\u0928\nP\fP\x0EP\u092B\vP\x03P\x03P\x05P\u092F\nP\x03Q\x03" + "Q\x05Q\u0933\nQ\x03Q\x05Q\u0936\nQ\x03R\x03R\x05R\u093A\nR\x03R\x03R\x03" + "R\x03R\x05R\u0940\nR\x03R\x05R\u0943\nR\x03S\x03S\x03S\x03T\x03T\x05T" + "\u094A\nT\x03U\x03U\x03U\x03U\x03U\x03U\x03U\x03U\x07U\u0954\nU\fU\x0E" + "U\u0957\vU\x03U\x03U\x03V\x03V\x03V\x03V\x07V\u095F\nV\fV\x0EV\u0962\v" + "V\x03V\x03V\x03V\x03V\x03V\x03V\x03V\x03V\x07V\u096C\nV\fV\x0EV\u096F" + "\vV\x03V\x03V\x03W\x03W\x03W\x03W\x07W\u0977\nW\fW\x0EW\u097A\vW\x03W" + "\x03W\x05W\u097E\nW\x03X\x03X\x03Y\x03Y\x03Z\x03Z\x05Z\u0986\nZ\x03[\x03" + "[\x03\\\x05\\\u098B\n\\\x03\\\x03\\\x03]\x03]\x03]\x03]\x03^\x03^\x03" + "^\x03_\x03_\x03_\x05_\u0999\n_\x03_\x03_\x03_\x03_\x03_\x07_\u09A0\n_" + "\f_\x0E_\u09A3\v_\x05_\u09A5\n_\x03_\x03_\x03_\x05_\u09AA\n_\x03_\x03" + "_\x03_\x07_\u09AF\n_\f_\x0E_\u09B2\v_\x05_\u09B4\n_\x03`\x03`\x03a\x05" + "a\u09B9\na\x03a\x03a\x07a\u09BD\na\fa\x0Ea\u09C0\va\x03a\x05a\u09C3\n" + "a\x03b\x03b\x03b\x05b\u09C8\nb\x03c\x03c\x03c\x05c\u09CD\nc\x03c\x03c" + "\x05c\u09D1\nc\x03c\x03c\x03c\x03c\x05c\u09D7\nc\x03c\x03c\x05c\u09DB" + "\nc\x03d\x05d\u09DE\nd\x03d\x03d\x03d\x05d\u09E3\nd\x03d\x05d\u09E6\n" + "d\x03d\x03d\x03d\x05d\u09EB\nd\x03d\x03d\x05d\u09EF\nd\x03d\x05d\u09F2" + "\nd\x03d\x05d\u09F5\nd\x03e\x03e\x03e\x03e\x05e\u09FB\ne\x03f\x03f\x03" + "f\x05f\u0A00\nf\x03f\x03f\x03f\x03f\x03f\x05f\u0A07\nf\x03g\x05g\u0A0A" + "\ng\x03g\x03g\x03g\x03g\x03g\x03g\x03g\x03g\x03g\x03g\x03g\x03g\x03g\x03" + "g\x03g\x03g\x05g\u0A1C\ng\x05g\u0A1E\ng\x03g\x05g\u0A21\ng\x03h\x03h\x03" + "h\x03h\x03i\x03i\x03i\x07i\u0A2A\ni\fi\x0Ei\u0A2D\vi\x03j\x03j\x03j\x03" + "j\x07j\u0A33\nj\fj\x0Ej\u0A36\vj\x03j\x03j\x03k\x03k\x05k\u0A3C\nk\x03" + "l\x03l\x03l\x03l\x07l\u0A42\nl\fl\x0El\u0A45\vl\x03l\x03l\x03m\x03m\x05" + "m\u0A4B\nm\x03n\x03n\x05n\u0A4F\nn\x03n\x05n\u0A52\nn\x03n\x03n\x03n\x03" + "n\x03n\x03n\x05n\u0A5A\nn\x03n\x03n\x03n\x03n\x03n\x03n\x05n\u0A62\nn" + "\x03n\x03n\x03n\x03n\x05n\u0A68\nn\x03o\x03o\x03o\x03o\x07o\u0A6E\no\f" + "o\x0Eo\u0A71\vo\x03o\x03o\x03p\x03p\x03p\x05p\u0A78\np\x03p\x03p\x03p" + "\x03p\x03p\x05p\u0A7F\np\x03p\x03p\x03p\x03p\x03p\x05p\u0A86\np\x05p\u0A88" + "\np\x03q\x03q\x03q\x03q\x03q\x03q\x03q\x03q\x03q\x07q\u0A93\nq\fq\x0E" + "q\u0A96\vq\x03q\x03q\x03q\x05q\u0A9B\nq\x05q\u0A9D\nq\x03q\x03q\x03q\x03" + "q\x03q\x03q\x07q\u0AA5\nq\fq\x0Eq\u0AA8\vq\x03q\x03q\x03q\x05q\u0AAD\n" + "q\x05q\u0AAF\nq\x03r\x03r\x03r\x03r\x03s\x03s\x05s\u0AB7\ns\x03t\x03t" + "\x05t\u0ABB\nt\x03u\x03u\x03u\x03u\x03u\x07u\u0AC2\nu\fu\x0Eu\u0AC5\v" + "u\x05u\u0AC7\nu\x03u\x03u\x03u\x03v\x05v\u0ACD\nv\x03v\x03v\x05v\u0AD1" + "\nv\x05v\u0AD3\nv\x03w\x03w\x03w\x03w\x03w\x03w\x03w\x05w\u0ADC\nw\x03" + "w\x03w\x03w\x03w\x03w\x03w\x03w\x03w\x03w\x03w\x05w\u0AE8\nw\x05w\u0AEA" + "\nw\x03w\x03w\x03w\x03w\x03w\x05w\u0AF1\nw\x03w\x03w\x03w\x03w\x03w\x05" + "w\u0AF8\nw\x03w\x03w\x03w\x03w\x05w\u0AFE\nw\x03w\x03w\x03w\x03w\x05w" + "\u0B04\nw\x05w\u0B06\nw\x03x\x03x\x03x\x07x\u0B0B\nx\fx\x0Ex\u0B0E\vx" + "\x03y\x03y\x03y\x07y\u0B13\ny\fy\x0Ey\u0B16\vy\x03z\x03z\x03z\x07z\u0B1B" + "\nz\fz\x0Ez\u0B1E\vz\x03{\x03{\x03{\x05{\u0B23\n{\x03|\x03|\x03|\x05|" + "\u0B28\n|\x03|\x03|\x03}\x03}\x03}\x05}\u0B2F\n}\x03}\x03}\x03~\x03~\x05" + "~\u0B35\n~\x03~\x03~\x05~\u0B39\n~\x05~\u0B3B\n~\x03\x7F\x03\x7F\x03\x7F" + "\x07\x7F\u0B40\n\x7F\f\x7F\x0E\x7F\u0B43\v\x7F\x03\x80\x03\x80\x03\x80" + "\x03\x80\x07\x80\u0B49\n\x80\f\x80\x0E\x80\u0B4C\v\x80\x03\x80\x03\x80" + "\x03\x81\x03\x81\x05\x81\u0B52\n\x81\x03\x82\x03\x82\x03\x82\x03\x82\x03" + "\x82\x03\x82\x07\x82\u0B5A\n\x82\f\x82\x0E\x82\u0B5D\v\x82\x03\x82\x03" + "\x82\x05\x82\u0B61\n\x82\x03\x83\x03\x83\x05\x83\u0B65\n\x83\x03\x84\x03" + "\x84\x03\x85\x03\x85\x03\x85\x03\x85\x03\x86\x03\x86\x05\x86\u0B6F\n\x86" + "\x03\x87\x03\x87\x03\x87\x07\x87\u0B74\n\x87\f\x87\x0E\x87\u0B77\v\x87" + "\x03\x88\x03\x88\x03\x88\x03\x88\x03\x88\x03\x88\x03\x88\x03\x88\x03\x88" + "\x03\x88\x05\x88\u0B83\n\x88\x05\x88\u0B85\n\x88\x03\x88\x03\x88\x03\x88" + "\x03\x88\x03\x88\x03\x88\x07\x88\u0B8D\n\x88\f\x88\x0E\x88\u0B90\v\x88" + "\x03\x89\x05\x89\u0B93\n\x89\x03\x89\x03\x89\x03\x89\x03\x89\x03\x89\x03" + "\x89\x05\x89\u0B9B\n\x89\x03\x89\x03\x89\x03\x89\x03\x89\x03\x89\x07\x89" + "\u0BA2\n\x89\f\x89\x0E\x89\u0BA5\v\x89\x03\x89\x03\x89\x03\x89\x05\x89" + "\u0BAA\n\x89\x03\x89\x03\x89\x03\x89\x03\x89\x03\x89\x03\x89\x05\x89\u0BB2" + "\n\x89\x03\x89\x03\x89\x03\x89\x05\x89\u0BB7\n\x89\x03\x89\x03\x89\x03" + "\x89\x03\x89\x03\x89\x03\x89\x03\x89\x03\x89\x07\x89\u0BC1\n\x89\f\x89" + "\x0E\x89\u0BC4\v\x89\x03\x89\x03\x89\x05\x89\u0BC8\n\x89\x03\x89\x05\x89" + "\u0BCB\n\x89\x03\x89\x03\x89\x03\x89\x03\x89\x05\x89\u0BD1\n\x89\x03\x89" + "\x03\x89\x05\x89\u0BD5\n\x89\x03\x89\x03\x89\x03\x89\x05\x89\u0BDA\n\x89" + "\x03\x89\x03\x89\x03\x89\x05\x89\u0BDF\n\x89\x03\x89\x03\x89\x03\x89\x05" + "\x89\u0BE4\n\x89\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x05\x8A\u0BEA\n\x8A\x03" + "\x8A\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x03" + "\x8A\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x03\x8A\x03" + "\x8A\x07\x8A\u0BFF\n\x8A\f\x8A\x0E\x8A\u0C02\v\x8A\x03\x8B\x03\x8B\x03" + "\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x05\x8C\u0C0C\n\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C" + "\x05\x8C\u0C18\n\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03" + "\x8C\x03\x8C\x06\x8C\u0C22\n\x8C\r\x8C\x0E\x8C\u0C23\x03\x8C\x03\x8C\x05" + "\x8C\u0C28\n\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x06\x8C\u0C2F" + "\n\x8C\r\x8C\x0E\x8C\u0C30\x03\x8C\x03\x8C\x05\x8C\u0C35\n\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x07\x8C\u0C45\n\x8C\f\x8C\x0E\x8C\u0C48" + "\v\x8C\x05\x8C\u0C4A\n\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03" + "\x8C\x05\x8C\u0C52\n\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C" + "\x03\x8C\x05\x8C\u0C5B\n\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03" + "\x8C\x03\x8C\x05\x8C\u0C64\n\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x06\x8C\u0C79\n\x8C\r\x8C\x0E" + "\x8C\u0C7A\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03" + "\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x05\x8C\u0C8B\n\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x07\x8C\u0C90\n\x8C\f\x8C\x0E\x8C\u0C93\v\x8C" + "\x05\x8C\u0C95\n\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03" + "\x8C\x05\x8C\u0C9E\n\x8C\x03\x8C\x03\x8C\x05\x8C\u0CA2\n\x8C\x03\x8C\x03" + "\x8C\x05\x8C\u0CA6\n\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x06\x8C\u0CB0\n\x8C\r\x8C\x0E\x8C\u0CB1\x03\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x05\x8C\u0CCB\n\x8C\x03\x8C\x03\x8C\x03\x8C\x03" + "\x8C\x03\x8C\x05\x8C\u0CD2\n\x8C\x03\x8C\x05\x8C\u0CD5\n\x8C\x03\x8C\x03" + "\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03" + "\x8C\x03\x8C\x03\x8C\x05\x8C\u0CE4\n\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C" + "\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x05\x8C\u0CF9\n\x8C\x03" + "\x8C\x03\x8C\x05\x8C\u0CFD\n\x8C\x05\x8C\u0CFF\n\x8C\x03\x8C\x03\x8C\x03" + "\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x03\x8C\x07\x8C\u0D09\n\x8C\f\x8C" + "\x0E\x8C\u0D0C\v\x8C\x03\x8D\x03\x8D\x03\x8D\x03\x8D\x03\x8D\x03\x8D\x03" + "\x8D\x05\x8D\u0D15\n\x8D\x03\x8E\x03\x8E\x03\x8E\x03\x8E\x03\x8E\x03\x8E" + "\x03\x8E\x03\x8E\x03\x8E\x03\x8E\x03\x8E\x06\x8E\u0D22\n\x8E\r\x8E\x0E" + "\x8E\u0D23\x05\x8E\u0D26\n\x8E\x03\x8F\x03\x8F\x03\x90\x03\x90\x03\x91" + "\x03\x91\x03\x92\x03\x92\x03\x93\x03\x93\x03\x93\x05\x93\u0D33\n\x93\x03" + "\x94\x03\x94\x05\x94\u0D37\n\x94\x03\x95\x03\x95\x03\x95\x06\x95\u0D3C" + "\n\x95\r\x95\x0E\x95\u0D3D\x03\x96\x03\x96\x03\x96\x05\x96\u0D43\n\x96" + "\x03\x97\x03\x97\x03\x97\x03\x97\x03\x97\x03\x98\x05\x98\u0D4B\n\x98\x03" + "\x98\x03\x98\x03\x98\x05\x98\u0D50\n\x98\x03\x99\x03\x99\x03\x9A\x03\x9A" + "\x03\x9B\x03\x9B\x03\x9B\x05\x9B\u0D59\n\x9B\x03\x9C\x03\x9C\x03\x9C\x03" + "\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03" + "\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03" + "\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x03\x9C\x05" + "\x9C\u0D79\n\x9C\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x03\x9D" + "\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x05\x9D" + "\u0D8A\n\x9D\x03\x9D\x03\x9D\x05\x9D\u0D8E\n\x9D\x03\x9D\x03\x9D\x03\x9D" + "\x03\x9D\x05\x9D\u0D94\n\x9D\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x05\x9D\u0D9A" + "\n\x9D\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x03\x9D\x07\x9D\u0DA1\n\x9D\f\x9D" + "\x0E\x9D\u0DA4\v\x9D\x03\x9D\x05\x9D\u0DA7\n\x9D\x05\x9D\u0DA9\n\x9D\x03" + "\x9E\x03\x9E\x03\x9E\x07\x9E\u0DAE\n\x9E\f\x9E\x0E\x9E\u0DB1\v\x9E\x03" + "\x9F\x03\x9F\x03\x9F\x07\x9F\u0DB6\n\x9F\f\x9F\x0E\x9F\u0DB9\v\x9F\x03" + "\xA0\x03\xA0\x03\xA0\x03\xA0\x03\xA0\x05\xA0\u0DC0\n\xA0\x03\xA1\x03\xA1" + "\x03\xA1\x03\xA2\x03\xA2\x03\xA2\x03\xA3\x03\xA3\x03\xA3\x07\xA3\u0DCB" + "\n\xA3\f\xA3\x0E\xA3\u0DCE\v\xA3\x03\xA4\x03\xA4\x03\xA4\x03\xA4\x05\xA4" + "\u0DD4\n\xA4\x03\xA4\x05\xA4\u0DD7\n\xA4\x03\xA5\x03\xA5\x03\xA5\x07\xA5" + "\u0DDC\n\xA5\f\xA5\x0E\xA5\u0DDF\v\xA5\x03\xA6\x03\xA6\x03\xA6\x07\xA6" + "\u0DE4\n\xA6\f\xA6\x0E\xA6\u0DE7\v\xA6\x03\xA7\x03\xA7\x03\xA7\x03\xA7" + "\x03\xA7\x05\xA7\u0DEE\n\xA7\x03\xA8\x03\xA8\x03\xA8\x03\xA8\x03\xA8\x03" + "\xA8\x03\xA8\x03\xA9\x03\xA9\x03\xA9\x07\xA9\u0DFA\n\xA9\f\xA9\x0E\xA9" + "\u0DFD\v\xA9\x03\xAA\x03\xAA\x05\xAA\u0E01\n\xAA\x03\xAA\x03\xAA\x03\xAA" + "\x05\xAA\u0E06\n\xAA\x03\xAA\x05\xAA\u0E09\n\xAA\x03\xAB\x03\xAB\x03\xAB" + "\x03\xAB\x03\xAB\x03\xAC\x03\xAC\x03\xAC\x03\xAC\x07\xAC\u0E14\n\xAC\f" + "\xAC\x0E\xAC\u0E17\v\xAC\x03\xAD\x03\xAD\x03\xAD\x03\xAD\x03\xAE\x03\xAE" + "\x03\xAE\x03\xAE\x03\xAE\x03\xAE\x03\xAE\x03\xAE\x03\xAE\x03\xAE\x03\xAE" + "\x07\xAE\u0E28\n\xAE\f\xAE\x0E\xAE\u0E2B\v\xAE\x03\xAE\x03\xAE\x03\xAE" + "\x03\xAE\x03\xAE\x07\xAE\u0E32\n\xAE\f\xAE\x0E\xAE\u0E35\v\xAE\x05\xAE" + "\u0E37\n\xAE\x03\xAE\x03\xAE\x03\xAE\x03\xAE\x03\xAE\x07\xAE\u0E3E\n\xAE" + "\f\xAE\x0E\xAE\u0E41\v\xAE\x05\xAE\u0E43\n\xAE\x05\xAE\u0E45\n\xAE\x03" + "\xAE\x05\xAE\u0E48\n\xAE\x03\xAE\x05\xAE\u0E4B\n\xAE\x03\xAF\x03\xAF\x03" + "\xAF\x03\xAF\x03\xAF\x03\xAF\x03\xAF\x03\xAF\x03\xAF\x03\xAF\x03\xAF\x03" + "\xAF\x03\xAF\x03\xAF\x03\xAF\x03\xAF\x05\xAF\u0E5D\n\xAF\x03\xB0\x03\xB0" + "\x03\xB0\x03\xB0\x03\xB0\x03\xB0\x03\xB0\x05\xB0\u0E66\n\xB0\x03\xB1\x03" + "\xB1\x03\xB1\x07\xB1\u0E6B\n\xB1\f\xB1\x0E\xB1\u0E6E\v\xB1\x03\xB2\x03" + "\xB2\x03\xB2\x03\xB2\x03\xB2\x03\xB2\x03\xB2\x03\xB2\x03\xB2\x05\xB2\u0E79" + "\n\xB2\x03\xB3\x03\xB3\x03\xB4\x03\xB4\x03\xB4\x07\xB4\u0E80\n\xB4\f\xB4" + "\x0E\xB4\u0E83\v\xB4\x03\xB5\x03\xB5\x03\xB5\x03\xB6\x03\xB6\x06\xB6\u0E8A" + "\n\xB6\r\xB6\x0E\xB6\u0E8B\x03\xB6\x05\xB6\u0E8F\n\xB6\x03\xB7\x03\xB7" + "\x03\xB7\x05\xB7\u0E94\n\xB7\x03\xB8\x03\xB8\x03\xB8\x03\xB8\x03\xB8\x03" + "\xB8\x05\xB8\u0E9C\n\xB8\x03\xB9\x03\xB9\x03\xB9\x05\xB9\u0EA1\n\xB9\x03" + "\xBA\x03\xBA\x03\xBB\x03\xBB\x05\xBB\u0EA7\n\xBB\x03\xBB\x03\xBB\x03\xBB" + "\x05\xBB\u0EAC\n\xBB\x03\xBB\x03\xBB\x03\xBB\x05\xBB\u0EB1\n\xBB\x03\xBB" + "\x03\xBB\x05\xBB\u0EB5\n\xBB\x03\xBB\x03\xBB\x05\xBB\u0EB9\n\xBB\x03\xBB" + "\x03\xBB\x05\xBB\u0EBD\n\xBB\x03\xBB\x03\xBB\x05\xBB\u0EC1\n\xBB\x03\xBB" + "\x03\xBB\x05\xBB\u0EC5\n\xBB\x03\xBB\x03\xBB\x05\xBB\u0EC9\n\xBB\x03\xBB" + "\x03\xBB\x05\xBB\u0ECD\n\xBB\x03\xBB\x05\xBB\u0ED0\n\xBB\x03\xBC\x03\xBC" + "\x03\xBC\x03\xBC\x03\xBC\x03\xBC\x03\xBC\x03\xBC\x03\xBC\x03\xBC\x03\xBC" + "\x05\xBC\u0EDD\n\xBC\x03\xBD\x03\xBD\x03\xBD\x05\xBD\u0EE2\n\xBD\x03\xBE" + "\x03\xBE\x05\xBE\u0EE6\n\xBE\x03\xBF\x03\xBF\x05\xBF\u0EEA\n\xBF\x03\xC0" + "\x03\xC0\x03\xC1\x03\xC1\x03\xC2\x03\xC2\x03\xC2\v\u041A\u045C\u0464\u0475" + "\u0490\u0499\u04A2\u04AB\u04D4\x02\x06b\u010E\u0112\u0116\xC3\x02\x02" + "\x04\x02\x06\x02\b\x02\n\x02\f\x02\x0E\x02\x10\x02\x12\x02\x14\x02\x16" + "\x02\x18\x02\x1A\x02\x1C\x02\x1E\x02 \x02\"\x02$\x02&\x02(\x02*\x02,\x02" + ".\x020\x022\x024\x026\x028\x02:\x02<\x02>\x02@\x02B\x02D\x02F\x02H\x02" + "J\x02L\x02N\x02P\x02R\x02T\x02V\x02X\x02Z\x02\\\x02^\x02`\x02b\x02d\x02" + "f\x02h\x02j\x02l\x02n\x02p\x02r\x02t\x02v\x02x\x02z\x02|\x02~\x02\x80" + "\x02\x82\x02\x84\x02\x86\x02\x88\x02\x8A\x02\x8C\x02\x8E\x02\x90\x02\x92" + "\x02\x94\x02\x96\x02\x98\x02\x9A\x02\x9C\x02\x9E\x02\xA0\x02\xA2\x02\xA4" + "\x02\xA6\x02\xA8\x02\xAA\x02\xAC\x02\xAE\x02\xB0\x02\xB2\x02\xB4\x02\xB6" + "\x02\xB8\x02\xBA\x02\xBC\x02\xBE\x02\xC0\x02\xC2\x02\xC4\x02\xC6\x02\xC8" + "\x02\xCA\x02\xCC\x02\xCE\x02\xD0\x02\xD2\x02\xD4\x02\xD6\x02\xD8\x02\xDA" + "\x02\xDC\x02\xDE\x02\xE0\x02\xE2\x02\xE4\x02\xE6\x02\xE8\x02\xEA\x02\xEC" + "\x02\xEE\x02\xF0\x02\xF2\x02\xF4\x02\xF6\x02\xF8\x02\xFA\x02\xFC\x02\xFE" + "\x02\u0100\x02\u0102\x02\u0104\x02\u0106\x02\u0108\x02\u010A\x02\u010C" + "\x02\u010E\x02\u0110\x02\u0112\x02\u0114\x02\u0116\x02\u0118\x02\u011A" + "\x02\u011C\x02\u011E\x02\u0120\x02\u0122\x02\u0124\x02\u0126\x02\u0128" + "\x02\u012A\x02\u012C\x02\u012E\x02\u0130\x02\u0132\x02\u0134\x02\u0136" + "\x02\u0138\x02\u013A\x02\u013C\x02\u013E\x02\u0140\x02\u0142\x02\u0144" + "\x02\u0146\x02\u0148\x02\u014A\x02\u014C\x02\u014E\x02\u0150\x02\u0152" + "\x02\u0154\x02\u0156\x02\u0158\x02\u015A\x02\u015C\x02\u015E\x02\u0160" + "\x02\u0162\x02\u0164\x02\u0166\x02\u0168\x02\u016A\x02\u016C\x02\u016E" + "\x02\u0170\x02\u0172\x02\u0174\x02\u0176\x02\u0178\x02\u017A\x02\u017C" + "\x02\u017E\x02\u0180\x02\u0182\x02\x02@\x04\x02PP\xE1\xE1\x04\x02$$\xF3" + "\xF3\x04\x02{{\x8C\x8C\x03\x0234\x04\x02\r\r))\x07\x0200<>ff|" + "|\x90\x90\x94\x94\x9B\x9B\x9E\x9E\xA1\xA1\xC0\xC0\xC8\xC8\xF5\xF5\u0103" + "\u0103\u0109\u0109\u013E\u013E\u0147\u0147\x13\x02\n\x10\x12=?eg{}\x8F" + "\x91\x93\x95\x9A\x9C\x9D\x9F\xA0\xA2\xBF\xC1\xC7\xC9\xF4\xF6\u0102\u0104" + "\u0108\u010A\u013D\u013F\u0146\u0148\u0159\x02\u113B\x02\u0187\x03\x02" + "\x02\x02\x04\u018C\x03\x02\x02\x02\x06\u04D7\x03\x02\x02\x02\b\u04DB\x03" + "\x02\x02\x02\n\u04DD\x03\x02\x02\x02\f\u04DF\x03\x02\x02\x02\x0E\u0589" + "\x03\x02\x02\x02\x10\u058B\x03\x02\x02\x02\x12\u059A\x03\x02\x02\x02\x14" + "\u05A0\x03\x02\x02\x02\x16\u05AC\x03\x02\x02\x02\x18\u05B9\x03\x02\x02" + "\x02\x1A\u05BC\x03\x02\x02\x02\x1C\u05C0\x03\x02\x02\x02\x1E\u060B\x03" + "\x02\x02\x02 \u060D\x03\x02\x02\x02\"\u0611\x03\x02\x02\x02$\u0626\x03" + "\x02\x02\x02&\u0628\x03\x02\x02\x02(\u062A\x03\x02\x02\x02*\u0631\x03" + "\x02\x02\x02,\u0633\x03\x02\x02\x02.\u063B\x03\x02\x02\x020\u0644\x03" + "\x02\x02\x022\u064F\x03\x02\x02\x024\u0661\x03\x02\x02\x026\u0664\x03" + "\x02\x02\x028\u066F\x03\x02\x02\x02:\u067F\x03\x02\x02\x02<\u0685\x03" + "\x02\x02\x02>\u0687\x03\x02\x02\x02@\u0692\x03\x02\x02\x02B\u0699\x03" + "\x02\x02\x02D\u06A4\x03\x02\x02\x02F\u06B5\x03\x02\x02\x02H\u06BD\x03" + "\x02\x02\x02J\u06BF\x03\x02\x02\x02L\u06C5\x03\x02\x02\x02N\u0700\x03" + "\x02\x02\x02P\u0702\x03\x02\x02\x02R\u0704\x03\x02\x02\x02T\u0706\x03" + "\x02\x02\x02V\u0708\x03\x02\x02\x02X\u070A\x03\x02\x02\x02Z\u070C\x03" + "\x02\x02\x02\\\u0714\x03\x02\x02\x02^\u0720\x03\x02\x02\x02`\u0754\x03" + "\x02\x02\x02b\u0757\x03\x02\x02\x02d\u077D\x03\x02\x02\x02f\u077F\x03" + "\x02\x02\x02h\u0787\x03\x02\x02\x02j\u07A8\x03\x02\x02\x02l\u07D6\x03" + "\x02\x02\x02n\u07EB\x03\x02\x02\x02p\u080B\x03\x02\x02\x02r\u0817\x03" + "\x02\x02\x02t\u081A\x03\x02\x02\x02v\u0823\x03\x02\x02\x02x\u0831\x03" + "\x02\x02\x02z\u0844\x03\x02\x02\x02|\u0858\x03\x02\x02\x02~\u085E\x03" + "\x02\x02\x02\x80\u0860\x03\x02\x02\x02\x82\u0868\x03\x02\x02\x02\x84\u086C" + "\x03\x02\x02\x02\x86\u086F\x03\x02\x02\x02\x88\u0872\x03\x02\x02\x02\x8A" + "\u088C\x03\x02\x02\x02\x8C\u088E\x03\x02\x02\x02\x8E\u08A3\x03\x02\x02" + "\x02\x90\u08B3\x03\x02\x02\x02\x92\u08DC\x03\x02\x02\x02\x94\u08E0\x03" + "\x02\x02\x02\x96\u08FB\x03\x02\x02\x02\x98\u08FF\x03\x02\x02\x02\x9A\u090E" + "\x03\x02\x02\x02\x9C\u0910\x03\x02\x02\x02\x9E\u092E\x03\x02\x02\x02\xA0" + "\u0930\x03\x02\x02\x02\xA2\u0937\x03\x02\x02\x02\xA4\u0944\x03\x02\x02" + "\x02\xA6\u0949\x03\x02\x02\x02\xA8\u094B\x03\x02\x02\x02\xAA\u095A\x03" + "\x02\x02\x02\xAC\u0972\x03\x02\x02\x02\xAE\u097F\x03\x02\x02\x02\xB0\u0981" + "\x03\x02\x02\x02\xB2\u0983\x03\x02\x02\x02\xB4\u0987\x03\x02\x02\x02\xB6" + "\u098A\x03\x02\x02\x02\xB8\u098E\x03\x02\x02\x02\xBA\u0992\x03\x02\x02" + "\x02\xBC\u0995\x03\x02\x02\x02\xBE\u09B5\x03\x02\x02\x02\xC0\u09C2\x03" + "\x02\x02\x02\xC2\u09C7\x03\x02\x02\x02\xC4\u09DA\x03\x02\x02\x02\xC6\u09F4" + "\x03\x02\x02\x02\xC8\u09FA\x03\x02\x02\x02\xCA\u09FC\x03\x02\x02\x02\xCC" + "\u0A20\x03\x02\x02\x02\xCE\u0A22\x03\x02\x02\x02\xD0\u0A26\x03\x02\x02" + "\x02\xD2\u0A2E\x03\x02\x02\x02\xD4\u0A39\x03\x02\x02\x02\xD6\u0A3D\x03" + "\x02\x02\x02\xD8\u0A48\x03\x02\x02\x02\xDA\u0A67\x03\x02\x02\x02\xDC\u0A69" + "\x03\x02\x02\x02\xDE\u0A87\x03\x02\x02\x02\xE0\u0A9C\x03\x02\x02\x02\xE2" + "\u0AB0\x03\x02\x02\x02\xE4\u0AB6\x03\x02\x02\x02\xE6\u0ABA\x03\x02\x02" + "\x02\xE8\u0ABC\x03\x02\x02\x02\xEA\u0AD2\x03\x02\x02\x02\xEC\u0B05\x03" + "\x02\x02\x02\xEE\u0B07\x03\x02\x02\x02\xF0\u0B0F\x03\x02\x02\x02\xF2\u0B17" + "\x03\x02\x02\x02\xF4\u0B1F\x03\x02\x02\x02\xF6\u0B27\x03\x02\x02\x02\xF8" + "\u0B2E\x03\x02\x02\x02\xFA\u0B32\x03\x02\x02\x02\xFC\u0B3C\x03\x02\x02"; private static readonly _serializedATNSegment2: string = "\x02\xFE\u0B44\x03\x02\x02\x02\u0100\u0B51\x03\x02\x02\x02\u0102\u0B60" + "\x03\x02\x02\x02\u0104\u0B64\x03\x02\x02\x02\u0106\u0B66\x03\x02\x02\x02" + "\u0108\u0B68\x03\x02\x02\x02\u010A\u0B6E\x03\x02\x02\x02\u010C\u0B70\x03" + "\x02\x02\x02\u010E\u0B84\x03\x02\x02\x02\u0110\u0BE3\x03\x02\x02\x02\u0112" + "\u0BE9\x03\x02\x02\x02\u0114\u0C03\x03\x02\x02\x02\u0116\u0CFE\x03\x02" + "\x02\x02\u0118\u0D14\x03\x02\x02\x02\u011A\u0D25\x03\x02\x02\x02\u011C" + "\u0D27\x03\x02\x02\x02\u011E\u0D29\x03\x02\x02\x02\u0120\u0D2B\x03\x02" + "\x02\x02\u0122\u0D2D\x03\x02\x02\x02\u0124\u0D2F\x03\x02\x02\x02\u0126" + "\u0D34\x03\x02\x02\x02\u0128\u0D3B\x03\x02\x02\x02\u012A\u0D3F\x03\x02" + "\x02\x02\u012C\u0D44\x03\x02\x02\x02\u012E\u0D4A\x03\x02\x02\x02\u0130" + "\u0D51\x03\x02\x02\x02\u0132\u0D53\x03\x02\x02\x02\u0134\u0D58\x03\x02" + "\x02\x02\u0136\u0D78\x03\x02\x02\x02\u0138\u0DA8\x03\x02\x02\x02\u013A" + "\u0DAA\x03\x02\x02\x02\u013C\u0DB2\x03\x02\x02\x02\u013E\u0DBF\x03\x02" + "\x02\x02\u0140\u0DC1\x03\x02\x02\x02\u0142\u0DC4\x03\x02\x02\x02\u0144" + "\u0DC7\x03\x02\x02\x02\u0146\u0DCF\x03\x02\x02\x02\u0148\u0DD8\x03\x02" + "\x02\x02\u014A\u0DE0\x03\x02\x02\x02\u014C\u0DED\x03\x02\x02\x02\u014E" + "\u0DEF\x03\x02\x02\x02\u0150\u0DF6\x03\x02\x02\x02\u0152\u0DFE\x03\x02" + "\x02\x02\u0154\u0E0A\x03\x02\x02\x02\u0156\u0E0F\x03\x02\x02\x02\u0158" + "\u0E18\x03\x02\x02\x02\u015A\u0E4A\x03\x02\x02\x02\u015C\u0E5C\x03\x02" + "\x02\x02\u015E\u0E65\x03\x02\x02\x02\u0160\u0E67\x03\x02\x02\x02\u0162" + "\u0E78\x03\x02\x02\x02\u0164\u0E7A\x03\x02\x02\x02\u0166\u0E7C\x03\x02" + "\x02\x02\u0168\u0E84\x03\x02\x02\x02\u016A\u0E8E\x03\x02\x02\x02\u016C" + "\u0E93\x03\x02\x02\x02\u016E\u0E9B\x03\x02\x02\x02\u0170\u0EA0\x03\x02" + "\x02\x02\u0172\u0EA2\x03\x02\x02\x02\u0174\u0ECF\x03\x02\x02\x02\u0176" + "\u0EDC\x03\x02\x02\x02\u0178\u0EE1\x03\x02\x02\x02\u017A\u0EE5\x03\x02" + "\x02\x02\u017C\u0EE9\x03\x02\x02\x02\u017E\u0EEB\x03\x02\x02\x02\u0180" + "\u0EED\x03\x02\x02\x02\u0182\u0EEF\x03\x02\x02\x02\u0184\u0186\x05\x04" + "\x03\x02\u0185\u0184\x03\x02\x02\x02\u0186\u0189\x03\x02\x02\x02\u0187" + "\u0185\x03\x02\x02\x02\u0187\u0188\x03\x02\x02\x02\u0188\u018A\x03\x02" + "\x02\x02\u0189\u0187\x03\x02\x02\x02\u018A\u018B\x07\x02\x02\x03\u018B" + "\x03\x03\x02\x02\x02\u018C\u018E\x05\x06\x04\x02\u018D\u018F\x07\x03\x02" + "\x02\u018E\u018D\x03\x02\x02\x02\u018E\u018F\x03\x02\x02\x02\u018F\x05" + "\x03\x02\x02\x02\u0190\u04D8\x05\x1C\x0F\x02\u0191\u0193\x05.\x18\x02" + "\u0192\u0191\x03\x02\x02\x02\u0192\u0193\x03\x02\x02\x02\u0193\u0194\x03" + "\x02\x02\x02\u0194\u04D8\x05N(\x02\u0195\u0196\x07\u0145\x02\x02\u0196" + "\u04D8\x05P)\x02\u0197\u0198\x07\u0145\x02\x02\u0198\u0199\x05&\x14\x02" + "\u0199\u019A\x05P)\x02\u019A\u04D8\x03\x02\x02\x02\u019B\u019C\x07\u0108" + "\x02\x02\u019C\u019F\x07\'\x02\x02\u019D\u01A0\x05\u016C\xB7\x02\u019E" + "\u01A0\x05\u0178\xBD\x02\u019F\u019D\x03\x02\x02\x02\u019F\u019E\x03\x02" + "\x02\x02\u01A0\u04D8\x03\x02\x02\x02\u01A1\u01A2\x07=\x02\x02\u01A2\u01A4" + "\x05&\x14\x02\u01A3\u01A5\x05\xB8]\x02\u01A4\u01A3\x03\x02\x02\x02\u01A4" + "\u01A5\x03\x02\x02\x02\u01A5\u01A6\x03\x02\x02\x02\u01A6\u01AE\x05R*\x02" + "\u01A7\u01AD\x05\x1A\x0E\x02\u01A8\u01AD\x05\x18\r\x02\u01A9\u01AA\x07" + "\u0155\x02\x02\u01AA\u01AB\t\x02\x02\x02\u01AB\u01AD\x056\x1C\x02\u01AC" + "\u01A7\x03\x02\x02\x02\u01AC\u01A8\x03\x02\x02\x02\u01AC\u01A9\x03\x02" + "\x02\x02\u01AD\u01B0\x03\x02\x02\x02\u01AE\u01AC\x03\x02\x02\x02\u01AE" + "\u01AF\x03\x02\x02\x02\u01AF\u04D8\x03\x02\x02\x02\u01B0\u01AE\x03\x02" + "\x02\x02\u01B1\u01B2\x07\r\x02\x02\u01B2\u01B3\x05&\x14\x02\u01B3\u01B4" + "\x05P)\x02\u01B4\u01B5\x07\u0108\x02\x02\u01B5\u01B6\t\x02\x02\x02\u01B6" + "\u01B7\x056\x1C\x02\u01B7\u04D8\x03\x02\x02\x02\u01B8\u01B9\x07\r\x02" + "\x02\u01B9\u01BA\x05&\x14\x02\u01BA\u01BB\x05P)\x02\u01BB\u01BC\x07\u0108" + "\x02\x02\u01BC\u01BD\x05\x18\r\x02\u01BD\u04D8\x03\x02\x02\x02\u01BE\u01BF" + "\x07a\x02\x02\u01BF\u01C1\x05&\x14\x02\u01C0\u01C2\x05\xBA^\x02\u01C1" + "\u01C0\x03\x02\x02\x02\u01C1\u01C2\x03\x02\x02\x02\u01C2\u01C3\x03\x02" + "\x02\x02\u01C3\u01C5\x05P)\x02\u01C4\u01C6\t\x03\x02\x02\u01C5\u01C4\x03" + "\x02\x02\x02\u01C5\u01C6\x03\x02\x02\x02\u01C6\u04D8\x03\x02\x02\x02\u01C7" + "\u01C8\x07\u010C\x02\x02\u01C8\u01CB\x05(\x15\x02\u01C9\u01CA\t\x04\x02" + "\x02\u01CA\u01CC\x05\xF0y\x02\u01CB\u01C9\x03\x02\x02\x02\u01CB\u01CC" + "\x03\x02\x02\x02\u01CC\u01D1\x03\x02\x02\x02\u01CD\u01CF\x07\xA2\x02\x02" + "\u01CE\u01CD\x03\x02\x02\x02\u01CE\u01CF\x03\x02\x02\x02\u01CF\u01D0\x03" + "\x02\x02\x02\u01D0\u01D2\x05\u0178\xBD\x02\u01D1\u01CE\x03\x02\x02\x02" + "\u01D1\u01D2\x03\x02\x02\x02\u01D2\u04D8\x03\x02\x02\x02\u01D3\u01D8\x05" + "\x10\t\x02\u01D4\u01D5\x07\x04\x02\x02\u01D5\u01D6\x05\u0148\xA5\x02\u01D6" + "\u01D7\x07\x05\x02\x02\u01D7\u01D9\x03\x02\x02\x02\u01D8\u01D4\x03\x02" + "\x02\x02\u01D8\u01D9\x03\x02\x02\x02\u01D9\u01DB\x03\x02\x02\x02\u01DA" + "\u01DC\x052\x1A\x02\u01DB\u01DA\x03\x02\x02\x02\u01DB\u01DC\x03\x02\x02" + "\x02\u01DC\u01DD\x03\x02\x02\x02\u01DD\u01E2\x054\x1B\x02\u01DE\u01E0" + "\x07\x16\x02\x02\u01DF\u01DE\x03\x02\x02\x02\u01DF\u01E0\x03\x02\x02\x02" + "\u01E0\u01E1\x03\x02\x02\x02\u01E1\u01E3\x05\x1C\x0F\x02\u01E2\u01DF\x03" + "\x02\x02\x02\u01E2\u01E3\x03\x02\x02\x02\u01E3\u04D8\x03\x02\x02\x02\u01E4" + "\u01E5\x07=\x02\x02\u01E5\u01E7\x07\u0120\x02\x02\u01E6\u01E8\x05\xB8" + "]\x02\u01E7\u01E6\x03\x02\x02\x02\u01E7\u01E8\x03\x02\x02\x02\u01E8\u01E9" + "\x03\x02\x02\x02\u01E9\u01EA\x05T+\x02\u01EA\u01EB\x07\xA2\x02\x02\u01EB" + "\u01F4\x05V,\x02\u01EC\u01F3\x052\x1A\x02\u01ED\u01F3\x05\xECw\x02\u01EE" + "\u01F3\x05F$\x02\u01EF\u01F3\x05\x18\r\x02\u01F0\u01F1\x07\u0124\x02\x02" + "\u01F1\u01F3\x056\x1C\x02\u01F2\u01EC\x03\x02\x02\x02\u01F2\u01ED\x03" + "\x02\x02\x02\u01F2\u01EE\x03\x02\x02\x02\u01F2\u01EF\x03\x02\x02\x02\u01F2" + "\u01F0\x03\x02\x02\x02\u01F3\u01F6\x03\x02\x02\x02\u01F4\u01F2\x03\x02" + "\x02\x02\u01F4\u01F5\x03\x02\x02\x02\u01F5\u04D8\x03\x02\x02\x02\u01F6" + "\u01F4\x03\x02\x02\x02\u01F7\u01FC\x05\x12\n\x02\u01F8\u01F9\x07\x04\x02" + "\x02\u01F9\u01FA\x05\u0148\xA5\x02\u01FA\u01FB\x07\x05\x02\x02\u01FB\u01FD" + "\x03\x02\x02\x02\u01FC\u01F8\x03\x02\x02\x02\u01FC\u01FD\x03\x02\x02\x02" + "\u01FD\u01FF\x03\x02\x02\x02\u01FE\u0200\x052\x1A\x02\u01FF\u01FE\x03" + "\x02\x02\x02\u01FF\u0200\x03\x02\x02\x02\u0200\u0201\x03\x02\x02\x02\u0201" + "\u0206\x054\x1B\x02\u0202\u0204\x07\x16\x02\x02\u0203\u0202\x03\x02\x02" + "\x02\u0203\u0204\x03\x02\x02\x02\u0204\u0205\x03\x02\x02\x02\u0205\u0207" + "\x05\x1C\x0F\x02\u0206\u0203\x03\x02\x02\x02\u0206\u0207\x03\x02\x02\x02" + "\u0207\u04D8\x03\x02\x02\x02\u0208\u0209\x07\x0F\x02\x02\u0209\u020A\x07" + "\u0120\x02\x02\u020A\u020C\x05V,\x02\u020B\u020D\x05\"\x12\x02\u020C\u020B" + "\x03\x02\x02\x02\u020C\u020D\x03\x02\x02\x02\u020D\u020E\x03\x02\x02\x02" + "\u020E\u020F\x079\x02\x02\u020F\u0217\x07\u0115\x02\x02\u0210\u0218\x05" + "\u016C\xB7\x02\u0211\u0212\x07w\x02\x02\u0212\u0213\x074\x02\x02\u0213" + "\u0218\x05\xD0i\x02\u0214\u0215\x07w\x02\x02\u0215\u0216\x07\f\x02\x02" + "\u0216\u0218\x074\x02\x02\u0217\u0210\x03\x02\x02\x02\u0217\u0211\x03" + "\x02\x02\x02\u0217\u0214\x03\x02\x02\x02\u0217\u0218\x03\x02\x02\x02\u0218" + "\u04D8\x03\x02\x02\x02\u0219\u021A\x07\x0F\x02\x02\u021A\u021D\x07\u0121" + "\x02\x02\u021B\u021C\t\x04\x02\x02\u021C\u021E\x05P)\x02\u021D\u021B\x03" + "\x02\x02\x02\u021D\u021E\x03\x02\x02\x02\u021E\u021F\x03\x02\x02\x02\u021F" + "\u0220\x079\x02\x02\u0220\u0222\x07\u0115\x02\x02\u0221\u0223\x05\u016C" + "\xB7\x02\u0222\u0221\x03\x02\x02\x02\u0222\u0223\x03\x02\x02\x02\u0223" + "\u04D8\x03\x02\x02\x02\u0224\u0225\x07\r\x02\x02\u0225\u0226\x07\u0120" + "\x02\x02\u0226\u0227\x05V,\x02\u0227\u0228\x07\n\x02\x02\u0228\u0229\t" + "\x05\x02\x02\u0229\u022A\x05\u013A\x9E\x02\u022A\u04D8\x03\x02\x02\x02" + "\u022B\u022C\x07\r\x02\x02\u022C\u022D\x07\u0120\x02\x02\u022D\u022E\x05" + "V,\x02\u022E\u022F\x07\n\x02\x02\u022F\u0230\t\x05\x02\x02\u0230\u0231" + "\x07\x04\x02\x02\u0231\u0232\x05\u013A\x9E\x02\u0232\u0233\x07\x05\x02" + "\x02\u0233\u04D8\x03\x02\x02\x02\u0234\u0235\x07\r\x02\x02\u0235\u0236" + "\x07\u0120\x02\x02\u0236\u0237\x05V,\x02\u0237\u0238\x07\xED\x02\x02\u0238" + "\u0239\x073\x02\x02\u0239\u023A\x05\xF0y\x02\u023A\u023B\x07\u0130\x02" + "\x02\u023B\u023C\x05\u0168\xB5\x02\u023C\u04D8\x03\x02\x02\x02\u023D\u023E" + "\x07\r\x02\x02\u023E\u023F\x07\u0120\x02\x02\u023F\u0240\x05V,\x02\u0240" + "\u0241\x07a\x02\x02\u0241\u0243\t\x05\x02\x02\u0242\u0244\x05\xBA^\x02" + "\u0243\u0242\x03\x02\x02\x02\u0243\u0244\x03\x02\x02\x02\u0244\u0245\x03" + "\x02\x02\x02\u0245\u0246\x07\x04\x02\x02\u0246\u0247\x05\xEEx\x02\u0247" + "\u0248\x07\x05\x02\x02\u0248\u04D8\x03\x02\x02\x02\u0249\u024A\x07\r\x02" + "\x02\u024A\u024B\x07\u0120\x02\x02\u024B\u024C\x05V,\x02\u024C\u024D\x07" + "a\x02\x02\u024D\u024F\t\x05\x02\x02\u024E\u0250\x05\xBA^\x02\u024F\u024E" + "\x03\x02\x02\x02\u024F\u0250\x03\x02\x02\x02\u0250\u0251\x03\x02\x02\x02" + "\u0251\u0252\x05\xEEx\x02\u0252\u04D8\x03\x02\x02\x02\u0253\u0258\x07" + "\r\x02\x02\u0254\u0255\x07\u0120\x02\x02\u0255\u0259\x05V,\x02\u0256\u0257" + "\x07\u014D\x02\x02\u0257\u0259\x05Z.\x02\u0258\u0254\x03\x02\x02\x02\u0258" + "\u0256\x03\x02\x02\x02\u0259\u025A\x03\x02\x02\x02\u025A\u025B\x07\xED" + "\x02\x02\u025B\u025C\x07\u0130\x02\x02\u025C\u025D\x05\xF0y\x02\u025D" + "\u04D8\x03\x02\x02\x02\u025E\u0263\x07\r\x02\x02\u025F\u0260\x07\u0120" + "\x02\x02\u0260\u0264\x05V,\x02\u0261\u0262\x07\u014D\x02\x02\u0262\u0264" + "\x05Z.\x02\u0263\u025F\x03\x02\x02\x02\u0263\u0261\x03\x02\x02\x02\u0264" + "\u0265\x03\x02\x02\x02\u0265\u0266\x07\u0108\x02\x02\u0266\u0267\x07\u0124" + "\x02\x02\u0267\u0268\x056\x1C\x02\u0268\u04D8\x03\x02\x02\x02\u0269\u026E" + "\x07\r\x02\x02\u026A\u026B\x07\u0120\x02\x02\u026B\u026F\x05V,\x02\u026C" + "\u026D\x07\u014D\x02\x02\u026D\u026F\x05Z.\x02\u026E\u026A\x03\x02\x02" + "\x02\u026E\u026C\x03\x02\x02\x02\u026F\u0270\x03\x02\x02\x02\u0270\u0271" + "\x07\u0143\x02\x02\u0271\u0273\x07\u0124\x02\x02\u0272\u0274\x05\xBA^" + "\x02\u0273\u0272\x03\x02\x02\x02\u0273\u0274\x03\x02\x02\x02\u0274\u0275" + "\x03\x02\x02\x02\u0275\u0276\x056\x1C\x02\u0276\u04D8\x03\x02\x02\x02" + "\u0277\u0278\x07\r\x02\x02\u0278\u0279\x07\u0120\x02\x02\u0279\u027A\x05" + "V,\x02\u027A\u027C\t\x06\x02\x02\u027B\u027D\x073\x02\x02\u027C\u027B" + "\x03\x02\x02\x02\u027C\u027D\x03\x02\x02\x02\u027D\u027E\x03\x02\x02\x02" + "\u027E\u0280\x05\xF0y\x02\u027F\u0281\x05\u0176\xBC\x02\u0280\u027F\x03" + "\x02\x02\x02\u0280\u0281\x03\x02\x02\x02\u0281\u04D8\x03\x02\x02\x02\u0282" + "\u0283\x07\r\x02\x02\u0283\u0284\x07\u0120\x02\x02\u0284\u0286\x05V,\x02" + "\u0285\u0287\x05\"\x12\x02\u0286\u0285\x03\x02\x02\x02\u0286\u0287\x03" + "\x02\x02\x02\u0287\u0288\x03\x02\x02\x02\u0288\u028A\x07)\x02\x02\u0289" + "\u028B\x073\x02\x02\u028A\u0289\x03\x02\x02\x02\u028A\u028B\x03\x02\x02" + "\x02\u028B\u028C\x03\x02\x02\x02\u028C\u028D\x05\xF0y\x02\u028D\u028F" + "\x05\u0146\xA4\x02\u028E\u0290\x05\u0134\x9B\x02\u028F\u028E\x03\x02\x02" + "\x02\u028F\u0290\x03\x02\x02\x02\u0290\u04D8\x03\x02\x02\x02\u0291\u0292" + "\x07\r\x02\x02\u0292\u0293\x07\u0120\x02\x02\u0293\u0295\x05V,\x02\u0294" + "\u0296\x05\"\x12\x02\u0295\u0294\x03\x02\x02\x02\u0295\u0296\x03\x02\x02" + "\x02\u0296\u0297\x03\x02\x02\x02\u0297\u0298\x07\xF0\x02\x02\u0298\u0299" + "\x074\x02\x02\u0299\u029A\x07\x04\x02\x02\u029A\u029B\x05\u013A\x9E\x02" + "\u029B\u029C\x07\x05\x02\x02\u029C\u04D8\x03\x02\x02\x02\u029D\u029E\x07" + "\r\x02\x02\u029E\u029F\x07\u0120\x02\x02\u029F\u02A1\x05V,\x02\u02A0\u02A2" + "\x05\"\x12\x02\u02A1\u02A0\x03\x02\x02\x02\u02A1\u02A2\x03\x02\x02\x02" + "\u02A2\u02A3\x03\x02\x02\x02\u02A3\u02A4\x07\u0108\x02\x02\u02A4\u02A5" + "\x07\u0105\x02\x02\u02A5\u02A9\x05\u0178\xBD\x02\u02A6\u02A7\x07\u0155" + "\x02\x02\u02A7\u02A8\x07\u0106\x02\x02\u02A8\u02AA\x056\x1C\x02\u02A9" + "\u02A6\x03\x02\x02\x02\u02A9\u02AA\x03\x02\x02\x02\u02AA\u04D8\x03\x02" + "\x02\x02\u02AB\u02AC\x07\r\x02\x02\u02AC\u02AD\x07\u0120\x02\x02\u02AD" + "\u02AF\x05V,\x02\u02AE\u02B0\x05\"\x12\x02\u02AF\u02AE\x03\x02\x02\x02" + "\u02AF\u02B0\x03\x02\x02\x02\u02B0\u02B1\x03\x02\x02\x02\u02B1\u02B2\x07" + "\u0108\x02\x02\u02B2\u02B3\x07\u0106\x02\x02\u02B3\u02B4\x056\x1C\x02" + "\u02B4\u04D8\x03\x02\x02\x02\u02B5\u02BA\x07\r\x02\x02\u02B6\u02B7\x07" + "\u0120\x02\x02\u02B7\u02BB\x05V,\x02\u02B8\u02B9\x07\u014D\x02\x02\u02B9" + "\u02BB\x05Z.\x02\u02BA\u02B6\x03\x02\x02\x02\u02BA\u02B8\x03\x02\x02\x02" + "\u02BB\u02BC\x03\x02\x02\x02\u02BC\u02BE\x07\n\x02\x02\u02BD\u02BF\x05" + "\xB8]\x02\u02BE\u02BD\x03\x02\x02\x02\u02BE\u02BF\x03\x02\x02\x02\u02BF" + "\u02C1\x03\x02\x02\x02\u02C0\u02C2\x05 \x11\x02\u02C1\u02C0\x03\x02\x02" + "\x02\u02C2\u02C3\x03\x02\x02\x02\u02C3\u02C1\x03\x02\x02\x02\u02C3\u02C4" + "\x03\x02\x02\x02\u02C4\u04D8\x03\x02\x02\x02\u02C5\u02C6\x07\r\x02\x02" + "\u02C6\u02C7\x07\u0120\x02\x02\u02C7\u02C8\x05V,\x02\u02C8\u02C9\x05\"" + "\x12\x02\u02C9\u02CA\x07\xED\x02\x02\u02CA\u02CB\x07\u0130\x02\x02\u02CB" + "\u02CC\x05\"\x12\x02\u02CC\u04D8\x03\x02\x02\x02\u02CD\u02D2\x07\r\x02" + "\x02\u02CE\u02CF\x07\u0120\x02\x02\u02CF\u02D3\x05V,\x02\u02D0\u02D1\x07" + "\u014D\x02\x02\u02D1\u02D3\x05Z.\x02\u02D2\u02CE\x03\x02\x02\x02\u02D2" + "\u02D0\x03\x02\x02\x02\u02D3\u02D4\x03\x02\x02\x02\u02D4\u02D6\x07a\x02" + "\x02\u02D5\u02D7\x05\xBA^\x02\u02D6\u02D5\x03\x02\x02\x02\u02D6\u02D7" + "\x03\x02\x02\x02\u02D7\u02D8\x03\x02\x02\x02\u02D8\u02DD\x05\"\x12\x02" + "\u02D9\u02DA\x07\x06\x02\x02\u02DA\u02DC\x05\"\x12\x02\u02DB\u02D9\x03" + "\x02\x02\x02\u02DC\u02DF\x03\x02\x02\x02\u02DD\u02DB\x03\x02\x02\x02\u02DD" + "\u02DE\x03\x02\x02\x02\u02DE\u02E1\x03\x02\x02\x02\u02DF\u02DD\x03\x02" + "\x02\x02\u02E0\u02E2\x07\xE2\x02\x02\u02E1\u02E0\x03\x02\x02\x02\u02E1" + "\u02E2\x03\x02\x02\x02\u02E2\u04D8\x03\x02\x02\x02\u02E3\u02E4\x07\r\x02" + "\x02\u02E4\u02E5\x07\u0120\x02\x02\u02E5\u02E7\x05V,\x02\u02E6\u02E8\x05" + "\"\x12\x02\u02E7\u02E6\x03\x02\x02\x02\u02E7\u02E8\x03\x02\x02\x02\u02E8" + "\u02E9\x03\x02\x02\x02\u02E9\u02EA\x07\u0108\x02\x02\u02EA\u02EB\x05\x18" + "\r\x02\u02EB\u04D8\x03\x02\x02\x02\u02EC\u02ED\x07\r\x02\x02\u02ED\u02EE" + "\x07\u0120\x02\x02\u02EE\u02EF\x05V,\x02\u02EF\u02F0\x07\xE9\x02\x02\u02F0" + "\u02F1\x07\xD7\x02\x02\u02F1\u04D8\x03\x02\x02\x02\u02F2\u02F3\x07a\x02" + "\x02\u02F3\u02F5\x07\u0120\x02\x02\u02F4\u02F6\x05\xBA^\x02\u02F5\u02F4" + "\x03\x02\x02\x02\u02F5\u02F6\x03\x02\x02\x02\u02F6\u02F7\x03\x02\x02\x02" + "\u02F7\u02F9\x05V,\x02\u02F8\u02FA\x07\xE2\x02\x02\u02F9\u02F8\x03\x02" + "\x02\x02\u02F9\u02FA\x03\x02\x02\x02\u02FA\u04D8\x03\x02\x02\x02\u02FB" + "\u02FC\x07a\x02\x02\u02FC\u02FE\x07\u014D\x02\x02\u02FD\u02FF\x05\xBA" + "^\x02\u02FE\u02FD\x03\x02\x02\x02\u02FE\u02FF\x03\x02\x02\x02\u02FF\u0300" + "\x03\x02\x02\x02\u0300\u04D8\x05Z.\x02\u0301\u0304\x07=\x02\x02\u0302" + "\u0303\x07\xCC\x02\x02\u0303\u0305\x07\xF0\x02\x02\u0304\u0302\x03\x02" + "\x02\x02\u0304\u0305\x03\x02\x02\x02\u0305\u030A\x03\x02\x02\x02\u0306" + "\u0308\x07\x80\x02\x02\u0307\u0306\x03\x02\x02\x02\u0307\u0308\x03\x02" + "\x02\x02\u0308\u0309\x03\x02\x02\x02\u0309\u030B\x07\u0125\x02\x02\u030A" + "\u0307\x03\x02\x02\x02\u030A\u030B\x03\x02\x02\x02\u030B\u030C\x03\x02" + "\x02\x02\u030C\u030E\x07\u014D\x02\x02\u030D\u030F\x05\xB8]\x02\u030E" + "\u030D\x03\x02\x02\x02\u030E\u030F\x03\x02\x02\x02\u030F\u0310\x03\x02" + "\x02\x02\u0310\u0312\x05X-\x02\u0311\u0313\x05\xD6l\x02\u0312\u0311\x03" + "\x02\x02\x02\u0312\u0313\x03\x02\x02\x02\u0313\u031C\x03\x02\x02\x02\u0314" + "\u031B\x05\x1A\x0E\x02\u0315\u0316\x07\xD6\x02\x02\u0316\u0317\x07\xC8" + "\x02\x02\u0317\u031B\x05\xCEh\x02\u0318\u0319\x07\u0124\x02\x02\u0319" + "\u031B\x056\x1C\x02\u031A\u0314\x03\x02\x02\x02\u031A\u0315\x03\x02\x02" + "\x02\u031A\u0318\x03\x02\x02\x02\u031B\u031E\x03\x02\x02\x02\u031C\u031A" + "\x03\x02\x02\x02\u031C\u031D\x03\x02\x02\x02\u031D\u031F\x03\x02\x02\x02" + "\u031E\u031C\x03\x02\x02\x02\u031F\u0320\x07\x16\x02\x02\u0320\u0321\x05" + "\x1C\x0F\x02\u0321\u04D8\x03\x02\x02\x02\u0322\u0325\x07=\x02\x02\u0323" + "\u0324\x07\xCC\x02\x02\u0324\u0326\x07\xF0\x02\x02\u0325\u0323\x03\x02" + "\x02\x02\u0325\u0326\x03\x02\x02\x02\u0326\u0328\x03\x02\x02\x02\u0327" + "\u0329\x07\x80\x02\x02\u0328\u0327\x03\x02\x02\x02\u0328\u0329\x03\x02" + "\x02\x02\u0329\u032A\x03\x02\x02\x02\u032A\u032B\x07\u0125\x02\x02\u032B" + "\u032C\x07\u014D\x02\x02\u032C\u0331\x05X-\x02\u032D\u032E\x07\x04\x02" + "\x02\u032E\u032F\x05\u0144\xA3\x02\u032F\u0330\x07\x05\x02\x02\u0330\u0332" + "\x03\x02\x02\x02\u0331\u032D\x03\x02\x02\x02\u0331\u0332\x03\x02\x02\x02" + "\u0332\u0333\x03\x02\x02\x02\u0333\u0336\x052\x1A\x02\u0334\u0335\x07" + "\xCB\x02\x02\u0335\u0337\x056\x1C\x02\u0336\u0334\x03\x02\x02\x02\u0336" + "\u0337\x03\x02\x02\x02\u0337\u04D8\x03\x02\x02\x02\u0338\u0339\x07\r\x02" + "\x02\u0339\u033A\x07\u014D\x02\x02\u033A\u033C\x05Z.\x02\u033B\u033D\x07" + "\x16\x02\x02\u033C\u033B\x03\x02\x02\x02\u033C\u033D\x03\x02\x02\x02\u033D" + "\u033E\x03\x02\x02\x02\u033E\u033F\x05\x1C\x0F\x02\u033F\u04D8\x03\x02" + "\x02\x02\u0340\u0343\x07=\x02\x02\u0341\u0342\x07\xCC\x02\x02\u0342\u0344" + "\x07\xF0\x02\x02\u0343\u0341\x03\x02\x02\x02\u0343\u0344\x03\x02\x02\x02" + "\u0344\u0346\x03\x02\x02\x02\u0345\u0347\x07\u0125\x02\x02\u0346\u0345" + "\x03\x02\x02\x02\u0346\u0347\x03\x02\x02\x02\u0347\u0348\x03\x02\x02\x02" + "\u0348\u034A\x07}\x02\x02\u0349\u034B\x05\xB8]\x02\u034A\u0349\x03\x02" + "\x02\x02\u034A\u034B\x03\x02\x02\x02\u034B\u034C\x03\x02\x02\x02\u034C" + "\u034D\x05\u0164\xB3\x02\u034D\u034E\x07\x16\x02\x02\u034E\u0358\x05\u0178" + "\xBD\x02\u034F\u0350\x07\u0147\x02\x02\u0350\u0355\x05L\'\x02\u0351\u0352" + "\x07\x06\x02\x02\u0352\u0354\x05L\'\x02\u0353\u0351\x03\x02\x02\x02\u0354" + "\u0357\x03\x02\x02\x02\u0355\u0353\x03\x02\x02\x02\u0355\u0356\x03\x02" + "\x02\x02\u0356\u0359\x03\x02\x02\x02\u0357\u0355\x03\x02\x02\x02\u0358" + "\u034F\x03\x02\x02\x02\u0358\u0359\x03\x02\x02\x02\u0359\u04D8\x03\x02" + "\x02\x02\u035A\u035C\x07a\x02\x02\u035B\u035D\x07\u0125\x02\x02\u035C" + "\u035B\x03\x02\x02\x02\u035C\u035D\x03\x02\x02\x02\u035D\u035E\x03\x02" + "\x02\x02\u035E\u0360\x07}\x02\x02\u035F\u0361\x05\xBA^\x02\u0360\u035F" + "\x03\x02\x02\x02\u0360\u0361\x03\x02\x02\x02\u0361\u0362\x03\x02\x02\x02" + "\u0362\u04D8\x05\u0162\xB2\x02\u0363\u0366\x07S\x02\x02\u0364\u0365\x07" + "\xCC\x02\x02\u0365\u0367\x07\xF0\x02\x02\u0366\u0364\x03\x02\x02\x02\u0366" + "\u0367\x03\x02\x02\x02\u0367\u0369\x03\x02\x02\x02\u0368\u036A\x07\u014B" + "\x02\x02\u0369\u0368\x03\x02\x02\x02\u0369\u036A\x03\x02\x02\x02\u036A" + "\u036B\x03\x02\x02\x02\u036B\u036D\x05\u0162\xB2\x02\u036C\u036E\x05\u0138" + "\x9D\x02\u036D\u036C\x03\x02\x02\x02\u036D\u036E\x03\x02\x02\x02\u036E" + "\u0370\x03\x02\x02\x02\u036F\u0371\x05\u0142\xA2\x02\u0370\u036F\x03\x02" + "\x02\x02\u0370\u0371\x03\x02\x02\x02\u0371\u04D8\x03\x02\x02\x02\u0372" + "\u0373\x07a\x02\x02\u0373\u0374\x07\u0125\x02\x02\u0374\u0376\x07\u014B" + "\x02\x02\u0375\u0377\x05\xBA^\x02\u0376\u0375\x03\x02\x02\x02\u0376\u0377" + "\x03\x02\x02\x02\u0377\u037B\x03\x02\x02\x02\u0378\u037C\x05V,\x02\u0379" + "\u037C\x05Z.\x02\u037A\u037C\x05\u0162\xB2\x02\u037B\u0378\x03\x02\x02" + "\x02\u037B\u0379\x03\x02\x02\x02\u037B\u037A\x03\x02\x02\x02\u037C\u04D8" + "\x03\x02\x02\x02\u037D\u037F\x07j\x02\x02\u037E\u0380\t\x07\x02\x02\u037F" + "\u037E\x03\x02\x02\x02\u037F\u0380\x03\x02\x02\x02\u0380\u0381\x03\x02" + "\x02\x02\u0381\u04D8\x05\x06\x04\x02\u0382\u0383\x07\u010C\x02\x02\u0383" + "\u0386\x07\u0121\x02\x02\u0384\u0385\t\x04\x02\x02\u0385\u0387\x05P)\x02" + "\u0386\u0384\x03\x02\x02\x02\u0386\u0387\x03\x02\x02\x02\u0387\u038C\x03" + "\x02\x02\x02\u0388\u038A\x07\xA2\x02\x02\u0389\u0388\x03\x02\x02\x02\u0389" + "\u038A\x03\x02\x02\x02\u038A\u038B\x03\x02\x02\x02\u038B\u038D\x05\u0178" + "\xBD\x02\u038C\u0389\x03\x02\x02\x02\u038C\u038D\x03\x02\x02\x02\u038D" + "\u04D8\x03\x02\x02\x02\u038E\u038F\x07\u010C\x02\x02\u038F\u0390\x07\u0120" + "\x02\x02\u0390\u0393\x07l\x02\x02\u0391\u0392\t\x04\x02\x02\u0392\u0394" + "\x05P)\x02\u0393\u0391\x03\x02\x02\x02\u0393\u0394\x03\x02\x02\x02\u0394" + "\u0395\x03\x02\x02\x02\u0395\u0396\x07\xA2\x02\x02\u0396\u0398\x05\u0178" + "\xBD\x02\u0397\u0399\x05\"\x12\x02\u0398\u0397\x03\x02\x02\x02\u0398\u0399" + "\x03\x02\x02\x02\u0399\u04D8\x03\x02\x02\x02\u039A\u039B\x07\u010C\x02" + "\x02\u039B\u039C\x07\u0124\x02\x02\u039C\u03A1\x05V,\x02\u039D\u039E\x07" + "\x04\x02\x02\u039E\u039F\x05:\x1E\x02\u039F\u03A0\x07\x05\x02\x02\u03A0" + "\u03A2\x03\x02\x02\x02\u03A1\u039D\x03\x02\x02\x02\u03A1\u03A2\x03\x02" + "\x02\x02\u03A2\u04D8\x03\x02\x02\x02\u03A3\u03A4\x07\u010C\x02\x02\u03A4" + "\u03A5\x074\x02\x02\u03A5\u03A6\t\x04\x02\x02\u03A6\u03A9\x05V,\x02\u03A7" + "\u03A8\t\x04\x02\x02\u03A8\u03AA\x05\xF0y\x02\u03A9\u03A7\x03\x02\x02" + "\x02\u03A9\u03AA\x03\x02\x02\x02\u03AA\u04D8\x03\x02\x02\x02\u03AB\u03AC" + "\x07\u010C\x02\x02\u03AC\u03AF\x07\u014E\x02\x02\u03AD\u03AE\t\x04\x02" + "\x02\u03AE\u03B0\x05P)\x02\u03AF\u03AD\x03\x02\x02\x02\u03AF\u03B0\x03" + "\x02\x02\x02\u03B0\u03B5\x03\x02\x02\x02\u03B1\u03B3\x07\xA2\x02\x02\u03B2" + "\u03B1\x03\x02\x02\x02\u03B2\u03B3\x03\x02\x02\x02\u03B3\u03B4\x03\x02" + "\x02\x02\u03B4\u03B6\x05\u0178\xBD\x02\u03B5\u03B2\x03\x02\x02\x02\u03B5" + "\u03B6\x03\x02\x02\x02\u03B6\u04D8\x03\x02\x02\x02\u03B7\u03B8\x07\u010C" + "\x02\x02\u03B8\u03B9\x07\xD7\x02\x02\u03B9\u03BB\x05V,\x02\u03BA\u03BC" + "\x05\"\x12\x02\u03BB\u03BA\x03\x02\x02\x02\u03BB\u03BC\x03\x02\x02\x02" + "\u03BC\u04D8\x03\x02\x02\x02\u03BD\u03BF\x07\u010C\x02\x02\u03BE\u03C0" + "\x05\x8EH\x02\u03BF\u03BE\x03\x02\x02\x02\u03BF\u03C0\x03\x02\x02\x02" + "\u03C0\u03C1\x03\x02\x02\x02\u03C1\u03C4\x07~\x02\x02\u03C2\u03C3\t\x04" + "\x02\x02\u03C3\u03C5\x05P)\x02\u03C4\u03C2\x03\x02\x02\x02\u03C4\u03C5" + "\x03\x02\x02\x02\u03C5\u03CD\x03\x02\x02\x02\u03C6\u03C8\x07\xA2\x02\x02" + "\u03C7\u03C6\x03\x02\x02\x02\u03C7\u03C8\x03\x02\x02\x02\u03C8\u03CB\x03" + "\x02\x02\x02\u03C9\u03CC\x05\xF0y\x02\u03CA\u03CC\x05\u0178\xBD\x02\u03CB" + "\u03C9\x03\x02\x02\x02\u03CB\u03CA\x03\x02\x02\x02\u03CC\u03CE\x03\x02" + "\x02\x02\u03CD\u03C7\x03\x02\x02\x02\u03CD\u03CE\x03\x02\x02\x02\u03CE" + "\u04D8\x03\x02\x02\x02\u03CF\u03D0\x07\u010C\x02\x02\u03D0\u03D1\x07=" + "\x02\x02\u03D1\u03D2\x07\u0120\x02\x02\u03D2\u03D5\x05V,\x02\u03D3\u03D4" + "\x07\x16\x02\x02\u03D4\u03D6\x07\u0105\x02\x02\u03D5\u03D3\x03\x02\x02" + "\x02\u03D5\u03D6\x03\x02\x02\x02\u03D6\u04D8\x03\x02\x02\x02\u03D7\u03D8" + "\x07\u010C\x02\x02\u03D8\u03D9\x07@\x02\x02\u03D9\u04D8\x05&\x14\x02\u03DA" + "\u03DB\x07\u010C\x02\x02\u03DB\u03E0\x07(\x02\x02\u03DC\u03DE\x07\xA2" + "\x02\x02\u03DD\u03DC\x03\x02\x02\x02\u03DD\u03DE\x03\x02\x02\x02\u03DE" + "\u03DF\x03\x02\x02\x02\u03DF\u03E1\x05\u0178\xBD\x02\u03E0\u03DD\x03\x02" + "\x02\x02\u03E0\u03E1\x03\x02\x02\x02\u03E1\u04D8\x03\x02\x02\x02\u03E2" + "\u03E3\t\b\x02\x02\u03E3\u03E5\x07}\x02\x02\u03E4\u03E6\x07l\x02\x02\u03E5" + "\u03E4\x03\x02\x02\x02\u03E5\u03E6\x03\x02\x02\x02\u03E6\u03E7\x03\x02" + "\x02\x02\u03E7\u04D8\x05*\x16\x02\u03E8\u03E9\t\b\x02\x02\u03E9\u03EB" + "\x07J\x02\x02\u03EA\u03EC\x07l\x02\x02\u03EB\u03EA\x03\x02\x02\x02\u03EB" + "\u03EC\x03\x02\x02\x02\u03EC\u03ED\x03\x02\x02\x02\u03ED\u04D8\x05P)\x02" + "\u03EE\u03F0\t\b\x02\x02\u03EF\u03F1\x07\u0120\x02\x02\u03F0\u03EF\x03" + "\x02\x02\x02\u03F0\u03F1\x03\x02\x02\x02\u03F1\u03F3\x03\x02\x02\x02\u03F2" + "\u03F4\t\t\x02\x02\u03F3\u03F2\x03\x02\x02\x02\u03F3\u03F4\x03\x02\x02" + "\x02\u03F4\u03F5\x03\x02\x02\x02\u03F5\u03F7\x05V,\x02\u03F6\u03F8\x05" + "\"\x12\x02\u03F7\u03F6\x03\x02\x02\x02\u03F7\u03F8\x03\x02\x02\x02\u03F8" + "\u03FA\x03\x02\x02\x02\u03F9\u03FB\x05,\x17\x02\u03FA\u03F9\x03\x02\x02" + "\x02\u03FA\u03FB\x03\x02\x02\x02\u03FB\u04D8\x03\x02\x02\x02\u03FC\u03FE" + "\t\b\x02\x02\u03FD\u03FF\x07\xE4\x02\x02\u03FE\u03FD\x03\x02\x02\x02\u03FE" + "\u03FF\x03\x02\x02\x02\u03FF\u0400\x03\x02\x02\x02\u0400\u04D8\x05\x1C" + "\x0F\x02\u0401\u0402\x075\x02\x02\u0402\u0403\x07\xC8\x02\x02\u0403\u0404" + "\x05&\x14\x02\u0404\u0405\x05P)\x02\u0405\u0406\x07\x99\x02\x02\u0406" + "\u0407\x05\u017A\xBE\x02\u0407\u04D8\x03\x02\x02\x02\u0408\u0409\x075" + "\x02\x02\u0409\u040A\x07\xC8\x02\x02\u040A\u040B\x07\u0120\x02\x02\u040B" + "\u040C\x05V,\x02\u040C\u040D\x07\x99\x02\x02\u040D\u040E\x05\u017A\xBE" + "\x02\u040E\u04D8\x03\x02\x02\x02\u040F\u0410\x07\xEC\x02\x02\u0410\u0411" + "\x07\u0120\x02\x02\u0411"; private static readonly _serializedATNSegment3: string = "\u04D8\x05V,\x02\u0412\u0413\x07\xEC\x02\x02\u0413\u0414\x07}\x02\x02" + "\u0414\u04D8\x05\u0162\xB2\x02\u0415\u041D\x07\xEC\x02\x02\u0416\u041E" + "\x05\u0178\xBD\x02\u0417\u0419\v\x02\x02\x02\u0418\u0417\x03\x02\x02\x02" + "\u0419\u041C\x03\x02\x02\x02\u041A\u041B\x03\x02\x02\x02\u041A\u0418\x03" + "\x02\x02\x02\u041B\u041E\x03\x02\x02\x02\u041C\u041A\x03\x02\x02\x02\u041D" + "\u0416\x03\x02\x02\x02\u041D\u041A\x03\x02\x02\x02\u041E\u04D8\x03\x02" + "\x02\x02\u041F\u0421\x07#\x02\x02\u0420\u0422\x07\x9F\x02\x02\u0421\u0420" + "\x03\x02\x02\x02\u0421\u0422\x03\x02\x02\x02\u0422\u0423\x03\x02\x02\x02" + "\u0423\u0424\x07\u0120\x02\x02\u0424\u0427\x05V,\x02\u0425\u0426\x07\xCB" + "\x02\x02\u0426\u0428\x056\x1C\x02\u0427\u0425\x03\x02\x02\x02\u0427\u0428" + "\x03\x02\x02\x02\u0428\u042D\x03\x02\x02\x02\u0429\u042B\x07\x16\x02\x02" + "\u042A\u0429\x03\x02\x02\x02\u042A\u042B\x03\x02\x02\x02\u042B\u042C\x03" + "\x02\x02\x02\u042C\u042E\x05\x1C\x0F\x02\u042D\u042A\x03\x02\x02\x02\u042D" + "\u042E\x03\x02\x02\x02\u042E\u04D8\x03\x02\x02\x02\u042F\u0430\x07\u013D" + "\x02\x02\u0430\u0432\x07\u0120\x02\x02\u0431\u0433\x05\xBA^\x02\u0432" + "\u0431\x03\x02\x02\x02\u0432\u0433\x03\x02\x02\x02\u0433\u0434\x03\x02" + "\x02\x02\u0434\u04D8\x05V,\x02\u0435\u0436\x07-\x02\x02\u0436\u04D8\x07" + "#\x02\x02\u0437\u0438\x07\xA7\x02\x02\u0438\u043A\x07H\x02\x02\u0439\u043B" + "\x07\xA8\x02\x02\u043A\u0439\x03\x02\x02\x02\u043A\u043B\x03\x02\x02\x02" + "\u043B\u043C\x03\x02\x02\x02\u043C\u043D\x07\x91\x02\x02\u043D\u043F\x05" + "\u0178\xBD\x02\u043E\u0440\x07\xD4\x02\x02\u043F\u043E\x03\x02\x02\x02" + "\u043F\u0440\x03\x02\x02\x02\u0440\u0441\x03\x02\x02\x02\u0441\u0442\x07" + "\x98\x02\x02\u0442\u0443\x07\u0120\x02\x02\u0443\u0445\x05V,\x02\u0444" + "\u0446\x05\"\x12\x02\u0445\u0444\x03\x02\x02\x02\u0445\u0446\x03\x02\x02" + "\x02\u0446\u04D8\x03\x02\x02\x02\u0447\u0448\x07\u0138\x02\x02\u0448\u0449" + "\x07\u0120\x02\x02\u0449\u044B\x05V,\x02\u044A\u044C\x05\"\x12\x02\u044B" + "\u044A\x03\x02\x02\x02\u044B\u044C\x03\x02\x02\x02\u044C\u04D8\x03\x02" + "\x02\x02\u044D\u044F\x07\xBA\x02\x02\u044E\u044D\x03\x02\x02\x02\u044E" + "\u044F\x03\x02\x02\x02\u044F\u0450\x03\x02\x02\x02\u0450\u0451\x07\xEE" + "\x02\x02\u0451\u0452\x07\u0120\x02\x02\u0452\u0455\x05V,\x02\u0453\u0454" + "\t\n\x02\x02\u0454\u0456\x07\xD7\x02\x02\u0455\u0453\x03\x02\x02\x02\u0455" + "\u0456\x03\x02\x02\x02\u0456\u04D8\x03\x02\x02\x02\u0457\u0458\t\v\x02" + "\x02\u0458\u045C\x05\u016C\xB7\x02\u0459\u045B\v\x02\x02\x02\u045A\u0459" + "\x03\x02\x02\x02\u045B\u045E\x03\x02\x02\x02\u045C\u045D\x03\x02\x02\x02" + "\u045C\u045A\x03\x02\x02\x02\u045D\u04D8\x03\x02\x02\x02\u045E\u045C\x03" + "\x02\x02\x02\u045F\u0460\x07\u0108\x02\x02\u0460\u0464\x07\xF8\x02\x02" + "\u0461\u0463\v\x02\x02\x02\u0462\u0461\x03\x02\x02\x02\u0463\u0466\x03" + "\x02\x02\x02\u0464\u0465\x03\x02\x02\x02\u0464\u0462\x03\x02\x02\x02\u0465" + "\u04D8\x03\x02\x02\x02\u0466\u0464\x03\x02\x02\x02\u0467\u0468\x07\u0108" + "\x02\x02\u0468\u0469\x07\u0128\x02\x02\u0469\u046A\x07\u0159\x02\x02\u046A" + "\u04D8\x05\u0124\x93\x02\u046B\u046C\x07\u0108\x02\x02\u046C\u046D\x07" + "\u0128\x02\x02\u046D\u046E\x07\u0159\x02\x02\u046E\u04D8\x05\b\x05\x02" + "\u046F\u0470\x07\u0108\x02\x02\u0470\u0471\x07\u0128\x02\x02\u0471\u0475" + "\x07\u0159\x02\x02\u0472\u0474\v\x02\x02\x02\u0473\u0472\x03\x02\x02\x02" + "\u0474\u0477\x03\x02\x02\x02\u0475\u0476\x03\x02\x02\x02\u0475\u0473\x03" + "\x02\x02\x02\u0476\u04D8\x03\x02\x02\x02\u0477\u0475\x03\x02\x02\x02\u0478" + "\u0479\x07\u0108\x02\x02\u0479\u047A\t\f\x02\x02\u047A\u04D8\x05\x80A" + "\x02\u047B\u047C\x07\u0108\x02\x02\u047C\u047D\t\f\x02\x02\u047D\u047E" + "\x07\x04\x02\x02\u047E\u047F\x05\xEEx\x02\u047F\u0480\x07\x05\x02\x02" + "\u0480\u0481\x07\u015A\x02\x02\u0481\u0482\x07\x04\x02\x02\u0482\u0483" + "\x05\x1C\x0F\x02\u0483\u0484\x07\x05\x02\x02\u0484\u04D8\x03\x02\x02\x02" + "\u0485\u0486\x07\u0108\x02\x02\u0486\u0487\x05\n\x06\x02\u0487\u0488\x07" + "\u015A\x02\x02\u0488\u0489\x05\f\x07\x02\u0489\u04D8\x03\x02\x02\x02\u048A" + "\u048B\x07\u0108\x02\x02\u048B\u0493\x05\n\x06\x02\u048C\u0490\x07\u015A" + "\x02\x02\u048D\u048F\v\x02\x02\x02\u048E\u048D\x03\x02\x02\x02\u048F\u0492" + "\x03\x02\x02\x02\u0490\u0491\x03\x02\x02\x02\u0490\u048E\x03\x02\x02\x02" + "\u0491\u0494\x03\x02\x02\x02\u0492\u0490\x03\x02\x02\x02\u0493\u048C\x03" + "\x02\x02\x02\u0493\u0494\x03\x02\x02\x02\u0494\u04D8\x03\x02\x02\x02\u0495" + "\u0499\x07\u0108\x02\x02\u0496\u0498\v\x02\x02\x02\u0497\u0496\x03\x02" + "\x02\x02\u0498\u049B\x03\x02\x02\x02\u0499\u049A\x03\x02\x02\x02\u0499" + "\u0497\x03\x02\x02\x02\u049A\u049C\x03\x02\x02\x02\u049B\u0499\x03\x02" + "\x02\x02\u049C\u049D\x07\u015A\x02\x02\u049D\u04D8\x05\f\x07\x02\u049E" + "\u04A2\x07\u0108\x02\x02\u049F\u04A1\v\x02\x02\x02\u04A0\u049F\x03\x02" + "\x02\x02\u04A1\u04A4\x03\x02\x02\x02\u04A2\u04A3\x03\x02\x02\x02\u04A2" + "\u04A0\x03\x02\x02\x02\u04A3\u04D8\x03\x02\x02\x02\u04A4\u04A2\x03\x02" + "\x02\x02\u04A5\u04A6\x07\xF1\x02\x02\u04A6\u04D8\x05\n\x06\x02\u04A7\u04AB" + "\x07\xF1\x02\x02\u04A8\u04AA\v\x02\x02\x02\u04A9\u04A8\x03\x02\x02\x02" + "\u04AA\u04AD\x03\x02\x02\x02\u04AB\u04AC\x03\x02\x02\x02\u04AB\u04A9\x03" + "\x02\x02\x02\u04AC\u04D8\x03\x02\x02\x02\u04AD\u04AB\x03\x02\x02\x02\u04AE" + "\u04AF\x07=\x02\x02\u04AF\u04B1\x07\x8E\x02\x02\u04B0\u04B2\x05\xB8]\x02" + "\u04B1\u04B0\x03\x02\x02\x02\u04B1\u04B2\x03\x02\x02\x02\u04B2\u04B3\x03" + "\x02\x02\x02\u04B3\u04B4\x05\u016C\xB7\x02\u04B4\u04B6\x07\xC8\x02\x02" + "\u04B5\u04B7\x07\u0120\x02\x02\u04B6\u04B5\x03\x02\x02\x02\u04B6\u04B7" + "\x03\x02\x02\x02\u04B7\u04B8\x03\x02\x02\x02\u04B8\u04BB\x05V,\x02\u04B9" + "\u04BA\x07\u0147\x02\x02\u04BA\u04BC\x05\u016C\xB7\x02\u04BB\u04B9\x03" + "\x02\x02\x02\u04BB\u04BC\x03\x02\x02\x02\u04BC\u04BD\x03\x02\x02\x02\u04BD" + "\u04BE\x07\x04\x02\x02\u04BE\u04BF\x05\xF2z\x02\u04BF\u04C2\x07\x05\x02" + "\x02\u04C0\u04C1\x07\xCB\x02\x02\u04C1\u04C3\x056\x1C\x02\u04C2\u04C0" + "\x03\x02\x02\x02\u04C2\u04C3\x03\x02\x02\x02\u04C3\u04D8\x03\x02\x02\x02" + "\u04C4\u04C5\x07a\x02\x02\u04C5\u04C7\x07\x8E\x02\x02\u04C6\u04C8\x05" + "\xBA^\x02\u04C7\u04C6\x03\x02\x02\x02\u04C7\u04C8\x03\x02\x02\x02\u04C8" + "\u04C9\x03\x02\x02\x02\u04C9\u04CA\x05\u016C\xB7\x02\u04CA\u04CC\x07\xC8" + "\x02\x02\u04CB\u04CD\x07\u0120\x02\x02\u04CC\u04CB\x03\x02\x02\x02\u04CC" + "\u04CD\x03\x02\x02\x02\u04CD\u04CE\x03\x02\x02\x02\u04CE\u04CF\x05V,\x02" + "\u04CF\u04D8\x03\x02\x02\x02\u04D0\u04D4\x05\x0E\b\x02\u04D1\u04D3\v\x02" + "\x02\x02\u04D2\u04D1\x03\x02\x02\x02\u04D3\u04D6\x03\x02\x02\x02\u04D4" + "\u04D5\x03\x02\x02\x02\u04D4\u04D2\x03\x02\x02\x02\u04D5\u04D8\x03\x02" + "\x02\x02\u04D6\u04D4\x03\x02\x02\x02\u04D7\u0190\x03\x02\x02\x02\u04D7" + "\u0192\x03\x02\x02\x02\u04D7\u0195\x03\x02\x02\x02\u04D7\u0197\x03\x02" + "\x02\x02\u04D7\u019B\x03\x02\x02\x02\u04D7\u01A1\x03\x02\x02\x02\u04D7" + "\u01B1\x03\x02\x02\x02\u04D7\u01B8\x03\x02\x02\x02\u04D7\u01BE\x03\x02" + "\x02\x02\u04D7\u01C7\x03\x02\x02\x02\u04D7\u01D3\x03\x02\x02\x02\u04D7" + "\u01E4\x03\x02\x02\x02\u04D7\u01F7\x03\x02\x02\x02\u04D7\u0208\x03\x02" + "\x02\x02\u04D7\u0219\x03\x02\x02\x02\u04D7\u0224\x03\x02\x02\x02\u04D7" + "\u022B\x03\x02\x02\x02\u04D7\u0234\x03\x02\x02\x02\u04D7\u023D\x03\x02" + "\x02\x02\u04D7\u0249\x03\x02\x02\x02\u04D7\u0253\x03\x02\x02\x02\u04D7" + "\u025E\x03\x02\x02\x02\u04D7\u0269\x03\x02\x02\x02\u04D7\u0277\x03\x02" + "\x02\x02\u04D7\u0282\x03\x02\x02\x02\u04D7\u0291\x03\x02\x02\x02\u04D7" + "\u029D\x03\x02\x02\x02\u04D7\u02AB\x03\x02\x02\x02\u04D7\u02B5\x03\x02" + "\x02\x02\u04D7\u02C5\x03\x02\x02\x02\u04D7\u02CD\x03\x02\x02\x02\u04D7" + "\u02E3\x03\x02\x02\x02\u04D7\u02EC\x03\x02\x02\x02\u04D7\u02F2\x03\x02" + "\x02\x02\u04D7\u02FB\x03\x02\x02\x02\u04D7\u0301\x03\x02\x02\x02\u04D7" + "\u0322\x03\x02\x02\x02\u04D7\u0338\x03\x02\x02\x02\u04D7\u0340\x03\x02" + "\x02\x02\u04D7\u035A\x03\x02\x02\x02\u04D7\u0363\x03\x02\x02\x02\u04D7" + "\u0372\x03\x02\x02\x02\u04D7\u037D\x03\x02\x02\x02\u04D7\u0382\x03\x02" + "\x02\x02\u04D7\u038E\x03\x02\x02\x02\u04D7\u039A\x03\x02\x02\x02\u04D7" + "\u03A3\x03\x02\x02\x02\u04D7\u03AB\x03\x02\x02\x02\u04D7\u03B7\x03\x02" + "\x02\x02\u04D7\u03BD\x03\x02\x02\x02\u04D7\u03CF\x03\x02\x02\x02\u04D7" + "\u03D7\x03\x02\x02\x02\u04D7\u03DA\x03\x02\x02\x02\u04D7\u03E2\x03\x02" + "\x02\x02\u04D7\u03E8\x03\x02\x02\x02\u04D7\u03EE\x03\x02\x02\x02\u04D7" + "\u03FC\x03\x02\x02\x02\u04D7\u0401\x03\x02\x02\x02\u04D7\u0408\x03\x02" + "\x02\x02\u04D7\u040F\x03\x02\x02\x02\u04D7\u0412\x03\x02\x02\x02\u04D7" + "\u0415\x03\x02\x02\x02\u04D7\u041F\x03\x02\x02\x02\u04D7\u042F\x03\x02" + "\x02\x02\u04D7\u0435\x03\x02\x02\x02\u04D7\u0437\x03\x02\x02\x02\u04D7" + "\u0447\x03\x02\x02\x02\u04D7\u044E\x03\x02\x02\x02\u04D7\u0457\x03\x02" + "\x02\x02\u04D7\u045F\x03\x02\x02\x02\u04D7\u0467\x03\x02\x02\x02\u04D7" + "\u046B\x03\x02\x02\x02\u04D7\u046F\x03\x02\x02\x02\u04D7\u0478\x03\x02" + "\x02\x02\u04D7\u047B\x03\x02\x02\x02\u04D7\u0485\x03\x02\x02\x02\u04D7" + "\u048A\x03\x02\x02\x02\u04D7\u0495\x03\x02\x02\x02\u04D7\u049E\x03\x02" + "\x02\x02\u04D7\u04A5\x03\x02\x02\x02\u04D7\u04A7\x03\x02\x02\x02\u04D7" + "\u04AE\x03\x02\x02\x02\u04D7\u04C4\x03\x02\x02\x02\u04D7\u04D0\x03\x02" + "\x02\x02\u04D8\x07\x03\x02\x02\x02\u04D9\u04DC\x05\u0178\xBD\x02\u04DA" + "\u04DC\x07\xA8\x02\x02\u04DB\u04D9\x03\x02\x02\x02\u04DB\u04DA\x03\x02" + "\x02\x02\u04DC\t\x03\x02\x02\x02\u04DD\u04DE\x05\u0170\xB9\x02\u04DE\v" + "\x03\x02\x02\x02\u04DF\u04E0\x05\u0172\xBA\x02\u04E0\r\x03\x02\x02\x02" + "\u04E1\u04E2\x07=\x02\x02\u04E2\u058A\x07\xF8\x02\x02\u04E3\u04E4\x07" + "a\x02\x02\u04E4\u058A\x07\xF8\x02\x02\u04E5\u04E7\x07\x81\x02\x02\u04E6" + "\u04E8\x07\xF8\x02\x02\u04E7\u04E6\x03\x02\x02\x02\u04E7\u04E8\x03\x02" + "\x02\x02\u04E8\u058A\x03\x02\x02\x02\u04E9\u04EB\x07\xF4\x02\x02\u04EA" + "\u04EC\x07\xF8\x02\x02\u04EB\u04EA\x03\x02\x02\x02\u04EB\u04EC\x03\x02" + "\x02\x02\u04EC\u058A\x03\x02\x02\x02\u04ED\u04EE\x07\u010C\x02\x02\u04EE" + "\u058A\x07\x81\x02\x02\u04EF\u04F0\x07\u010C\x02\x02\u04F0\u04F2\x07\xF8" + "\x02\x02\u04F1\u04F3\x07\x81\x02\x02\u04F2\u04F1\x03\x02\x02\x02\u04F2" + "\u04F3\x03\x02\x02\x02\u04F3\u058A\x03\x02\x02\x02\u04F4\u04F5\x07\u010C" + "\x02\x02\u04F5\u058A\x07\xE0\x02\x02\u04F6\u04F7\x07\u010C\x02\x02\u04F7" + "\u058A\x07\xF9\x02\x02\u04F8\u04F9\x07\u010C\x02\x02\u04F9\u04FA\x07@" + "\x02\x02\u04FA\u058A\x07\xF9\x02\x02\u04FB\u04FC\x07k\x02\x02\u04FC\u058A" + "\x07\u0120\x02\x02\u04FD\u04FE\x07\x8B\x02\x02\u04FE\u058A\x07\u0120\x02" + "\x02\u04FF\u0500\x07\u010C\x02\x02\u0500\u058A\x078\x02\x02\u0501\u0502" + "\x07\u010C\x02\x02\u0502\u0503\x07=\x02\x02\u0503\u058A\x07\u0120\x02" + "\x02\u0504\u0505\x07\u010C\x02\x02\u0505\u058A\x07\u0134\x02\x02\u0506" + "\u0507\x07\u010C\x02\x02\u0507\u058A\x07\x8F\x02\x02\u0508\u0509\x07\u010C" + "\x02\x02\u0509\u058A\x07\xAB\x02\x02\u050A\u050B\x07=\x02\x02\u050B\u058A" + "\x07\x8E\x02\x02\u050C\u050D\x07a\x02\x02\u050D\u058A\x07\x8E\x02\x02" + "\u050E\u050F\x07\r\x02\x02\u050F\u058A\x07\x8E\x02\x02\u0510\u0511\x07" + "\xAA\x02\x02\u0511\u058A\x07\u0120\x02\x02\u0512\u0513\x07\xAA\x02\x02" + "\u0513\u058A\x07J\x02\x02\u0514\u0515\x07\u0141\x02\x02\u0515\u058A\x07" + "\u0120\x02\x02\u0516\u0517\x07\u0141\x02\x02\u0517\u058A\x07J\x02\x02" + "\u0518\u0519\x07=\x02\x02\u0519\u051A\x07\u0125\x02\x02\u051A\u058A\x07" + "\xAE\x02\x02\u051B\u051C\x07a\x02\x02\u051C\u051D\x07\u0125\x02\x02\u051D" + "\u058A\x07\xAE\x02\x02\u051E\u051F\x07\r\x02\x02\u051F\u0520\x07\u0120" + "\x02\x02\u0520\u0521\x05V,\x02\u0521\u0522\x07\xC2\x02\x02\u0522\u0523" + "\x07/\x02\x02\u0523\u058A\x03\x02\x02\x02\u0524\u0525\x07\r\x02\x02\u0525" + "\u0526\x07\u0120\x02\x02\u0526\u0527\x05V,\x02\u0527\u0528\x07/\x02\x02" + "\u0528\u0529\x07!\x02\x02\u0529\u058A\x03\x02\x02\x02\u052A\u052B\x07" + "\r\x02\x02\u052B\u052C\x07\u0120\x02\x02\u052C\u052D\x05V,\x02\u052D\u052E" + "\x07\xC2\x02\x02\u052E\u052F\x07\u0112\x02\x02\u052F\u058A\x03\x02\x02" + "\x02\u0530\u0531\x07\r\x02\x02\u0531\u0532\x07\u0120\x02\x02\u0532\u0533" + "\x05V,\x02\u0533\u0534\x07\u010E\x02\x02\u0534\u0535\x07!\x02\x02\u0535" + "\u058A\x03\x02\x02\x02\u0536\u0537\x07\r\x02\x02\u0537\u0538\x07\u0120" + "\x02\x02\u0538\u0539\x05V,\x02\u0539\u053A\x07\xC2\x02\x02\u053A\u053B" + "\x07\u010E\x02\x02\u053B\u058A\x03\x02\x02\x02\u053C\u053D\x07\r\x02\x02" + "\u053D\u053E\x07\u0120\x02\x02\u053E\u053F\x05V,\x02\u053F\u0540\x07\xC2" + "\x02\x02\u0540\u0541\x07\u0116\x02\x02\u0541\u0542\x07\x16\x02\x02\u0542" + "\u0543\x07[\x02\x02\u0543\u058A\x03\x02\x02\x02\u0544\u0545\x07\r\x02" + "\x02\u0545\u0546\x07\u0120\x02\x02\u0546\u0547\x05V,\x02\u0547\u0548\x07" + "\u0108\x02\x02\u0548\u0549\x07\u010E\x02\x02\u0549\u054A\x07\xA9\x02\x02" + "\u054A\u058A\x03\x02\x02\x02\u054B\u054C\x07\r\x02\x02\u054C\u054D\x07" + "\u0120\x02\x02\u054D\u054E\x05V,\x02\u054E\u054F\x07g\x02\x02\u054F\u0550" + "\x07\xD5\x02\x02\u0550\u058A\x03\x02\x02\x02\u0551\u0552\x07\r\x02\x02" + "\u0552\u0553\x07\u0120\x02\x02\u0553\u0554\x05V,\x02\u0554\u0555\x07\x14" + "\x02\x02\u0555\u0556\x07\xD5\x02\x02\u0556\u058A\x03\x02\x02\x02\u0557" + "\u0558\x07\r\x02\x02\u0558\u0559\x07\u0120\x02\x02\u0559\u055A\x05V,\x02" + "\u055A\u055B\x07\u013B\x02\x02\u055B\u055C\x07\xD5\x02\x02\u055C\u058A" + "\x03\x02\x02\x02\u055D\u055E\x07\r\x02\x02\u055E\u055F\x07\u0120\x02\x02" + "\u055F\u0560\x05V,\x02\u0560\u0561\x07\u0131\x02\x02\u0561\u058A\x03\x02" + "\x02\x02\u0562\u0563\x07\r\x02\x02\u0563\u0564\x07\u0120\x02\x02\u0564" + "\u0566\x05V,\x02\u0565\u0567\x05\"\x12\x02\u0566\u0565\x03\x02\x02\x02" + "\u0566\u0567\x03\x02\x02\x02\u0567\u0568\x03\x02\x02\x02\u0568\u0569\x07" + "7\x02\x02\u0569\u058A\x03\x02\x02\x02\u056A\u056B\x07\r\x02\x02\u056B" + "\u056C\x07\u0120\x02\x02\u056C\u056E\x05V,\x02\u056D\u056F\x05\"\x12\x02" + "\u056E\u056D\x03\x02\x02\x02\u056E\u056F\x03\x02\x02\x02\u056F\u0570\x03" + "\x02\x02\x02\u0570\u0571\x07:\x02\x02\u0571\u058A\x03\x02\x02\x02\u0572" + "\u0573\x07\r\x02\x02\u0573\u0574\x07\u0120\x02\x02\u0574\u0576\x05V,\x02" + "\u0575\u0577\x05\"\x12\x02\u0576\u0575\x03\x02\x02\x02\u0576\u0577\x03" + "\x02\x02\x02\u0577\u0578\x03\x02\x02\x02\u0578\u0579\x07\u0108\x02\x02" + "\u0579\u057A\x07s\x02\x02\u057A\u058A\x03\x02\x02\x02\u057B\u057C\x07" + "\r\x02\x02\u057C\u057D\x07\u0120\x02\x02\u057D\u057F\x05V,\x02\u057E\u0580" + "\x05\"\x12\x02\u057F\u057E\x03\x02\x02\x02\u057F\u0580\x03\x02\x02\x02" + "\u0580\u0581\x03\x02\x02\x02\u0581\u0582\x07\xF0\x02\x02\u0582\u0583\x07" + "4\x02\x02\u0583\u058A\x03\x02\x02\x02\u0584\u0585\x07\u0114\x02\x02\u0585" + "\u058A\x07\u0133\x02\x02\u0586\u058A\x076\x02\x02\u0587\u058A\x07\xFA" + "\x02\x02\u0588\u058A\x07Z\x02\x02\u0589\u04E1\x03\x02\x02\x02\u0589\u04E3" + "\x03\x02\x02\x02\u0589\u04E5\x03\x02\x02\x02\u0589\u04E9\x03\x02\x02\x02" + "\u0589\u04ED\x03\x02\x02\x02\u0589\u04EF\x03\x02\x02\x02\u0589\u04F4\x03" + "\x02\x02\x02\u0589\u04F6\x03\x02\x02\x02\u0589\u04F8\x03\x02\x02\x02\u0589" + "\u04FB\x03\x02\x02\x02\u0589\u04FD\x03\x02\x02\x02\u0589\u04FF\x03\x02" + "\x02\x02\u0589\u0501\x03\x02\x02\x02\u0589\u0504\x03\x02\x02\x02\u0589" + "\u0506\x03\x02\x02\x02\u0589\u0508\x03\x02\x02\x02\u0589\u050A\x03\x02" + "\x02\x02\u0589\u050C\x03\x02\x02\x02\u0589\u050E\x03\x02\x02\x02\u0589" + "\u0510\x03\x02\x02\x02\u0589\u0512\x03\x02\x02\x02\u0589\u0514\x03\x02" + "\x02\x02\u0589\u0516\x03\x02\x02\x02\u0589\u0518\x03\x02\x02\x02\u0589" + "\u051B\x03\x02\x02\x02\u0589\u051E\x03\x02\x02\x02\u0589\u0524\x03\x02" + "\x02\x02\u0589\u052A\x03\x02\x02\x02\u0589\u0530\x03\x02\x02\x02\u0589" + "\u0536\x03\x02\x02\x02\u0589\u053C\x03\x02\x02\x02\u0589\u0544\x03\x02" + "\x02\x02\u0589\u054B\x03\x02\x02\x02\u0589\u0551\x03\x02\x02\x02\u0589" + "\u0557\x03\x02\x02\x02\u0589\u055D\x03\x02\x02\x02\u0589\u0562\x03\x02" + "\x02\x02\u0589\u056A\x03\x02\x02\x02\u0589\u0572\x03\x02\x02\x02\u0589" + "\u057B\x03\x02\x02\x02\u0589\u0584\x03\x02\x02\x02\u0589\u0586\x03\x02" + "\x02\x02\u0589\u0587\x03\x02\x02\x02\u0589\u0588\x03\x02\x02\x02\u058A" + "\x0F\x03\x02\x02\x02\u058B\u058D\x07=\x02\x02\u058C\u058E\x07\u0125\x02" + "\x02\u058D\u058C\x03\x02\x02\x02\u058D\u058E\x03\x02\x02\x02\u058E\u0590" + "\x03\x02\x02\x02\u058F\u0591\x07m\x02\x02\u0590\u058F\x03\x02\x02\x02" + "\u0590\u0591\x03\x02\x02\x02\u0591\u0592\x03\x02\x02\x02\u0592\u0594\x07" + "\u0120\x02\x02\u0593\u0595\x05\xB8]\x02\u0594\u0593\x03\x02\x02\x02\u0594" + "\u0595\x03\x02\x02\x02\u0595\u0596\x03\x02\x02\x02\u0596\u0597\x05T+\x02" + "\u0597\x11\x03\x02\x02\x02\u0598\u0599\x07=\x02\x02\u0599\u059B\x07\xCC" + "\x02\x02\u059A\u0598\x03\x02\x02\x02\u059A\u059B\x03\x02\x02\x02\u059B" + "\u059C\x03\x02\x02\x02\u059C\u059D\x07\xF0\x02\x02\u059D\u059E\x07\u0120" + "\x02\x02\u059E\u059F\x05T+\x02\u059F\x13\x03\x02\x02\x02\u05A0\u05A1\x07" + "/\x02\x02\u05A1\u05A2\x07!\x02\x02\u05A2\u05A6\x05\xCEh\x02\u05A3\u05A4" + "\x07\u0112\x02\x02\u05A4\u05A5\x07!\x02\x02\u05A5\u05A7\x05\xD2j\x02\u05A6" + "\u05A3\x03\x02\x02\x02\u05A6\u05A7\x03\x02\x02\x02\u05A7\u05A8\x03\x02" + "\x02\x02\u05A8\u05A9\x07\x98\x02\x02\u05A9\u05AA\x07\u0178\x02\x02\u05AA" + "\u05AB\x07 \x02\x02\u05AB\x15\x03\x02\x02\x02\u05AC\u05AD\x07\u010E\x02" + "\x02\u05AD\u05AE\x07!\x02\x02\u05AE\u05AF\x05\xCEh\x02\u05AF\u05B2\x07" + "\xC8\x02\x02\u05B0\u05B3\x05B\"\x02\u05B1\u05B3\x05D#\x02\u05B2\u05B0" + "\x03\x02\x02\x02\u05B2\u05B1\x03\x02\x02\x02\u05B3\u05B7\x03\x02\x02\x02" + "\u05B4\u05B5\x07\u0116\x02\x02\u05B5\u05B6\x07\x16\x02\x02\u05B6\u05B8" + "\x07[\x02\x02\u05B7\u05B4\x03\x02\x02\x02\u05B7\u05B8\x03\x02\x02\x02" + "\u05B8\x17\x03\x02\x02\x02\u05B9\u05BA\x07\xA9\x02\x02\u05BA\u05BB\x05" + "\u0178\xBD\x02\u05BB\x19\x03\x02\x02\x02\u05BC\u05BD\x075\x02\x02\u05BD" + "\u05BE\x05\u0178\xBD\x02\u05BE\x1B\x03\x02\x02\x02\u05BF\u05C1\x05.\x18" + "\x02\u05C0\u05BF\x03\x02\x02\x02\u05C0\u05C1\x03\x02\x02\x02\u05C1\u05C2" + "\x03\x02\x02\x02\u05C2\u05C3\x05b2\x02\u05C3\u05C4\x05^0\x02\u05C4\x1D" + "\x03\x02\x02\x02\u05C5\u05C6\x07\x93\x02\x02\u05C6\u05C8\x07\xD4\x02\x02" + "\u05C7\u05C9\x07\u0120\x02\x02\u05C8\u05C7\x03\x02\x02\x02\u05C8\u05C9" + "\x03\x02\x02\x02\u05C9\u05CA\x03\x02\x02\x02\u05CA\u05CF\x05V,\x02\u05CB" + "\u05CD\x05\"\x12\x02\u05CC\u05CE\x05\xB8]\x02\u05CD\u05CC\x03\x02\x02" + "\x02\u05CD\u05CE\x03\x02\x02\x02\u05CE\u05D0\x03\x02\x02\x02\u05CF\u05CB" + "\x03\x02\x02\x02\u05CF\u05D0\x03\x02\x02\x02\u05D0\u05D4\x03\x02\x02\x02" + "\u05D1\u05D2\x07!\x02\x02\u05D2\u05D5\x07\xBB\x02\x02\u05D3\u05D5\x05" + "\xCEh\x02\u05D4\u05D1\x03\x02\x02\x02\u05D4\u05D3\x03\x02\x02\x02\u05D4" + "\u05D5\x03\x02\x02\x02\u05D5\u060C\x03\x02\x02\x02\u05D6\u05D7\x07\x93" + "\x02\x02\u05D7\u05D9\x07\x98\x02\x02\u05D8\u05DA\x07\u0120\x02\x02\u05D9" + "\u05D8\x03\x02\x02\x02\u05D9\u05DA\x03\x02\x02\x02\u05DA\u05DB\x03\x02" + "\x02\x02\u05DB\u05DD\x05V,\x02\u05DC\u05DE\x05\"\x12\x02\u05DD\u05DC\x03" + "\x02\x02\x02\u05DD\u05DE\x03\x02\x02\x02\u05DE\u05E0\x03\x02\x02\x02\u05DF" + "\u05E1\x05\xB8]\x02\u05E0\u05DF\x03\x02\x02\x02\u05E0\u05E1\x03\x02\x02" + "\x02\u05E1\u05E5\x03\x02\x02\x02\u05E2\u05E3\x07!\x02\x02\u05E3\u05E6" + "\x07\xBB\x02\x02\u05E4\u05E6\x05\xCEh\x02\u05E5\u05E2\x03\x02\x02\x02" + "\u05E5\u05E4\x03\x02\x02\x02\u05E5\u05E6\x03\x02\x02\x02\u05E6\u060C\x03" + "\x02\x02\x02\u05E7\u05E8\x07\x93\x02\x02\u05E8\u05EA\x07\x98\x02\x02\u05E9" + "\u05EB\x07\u0120\x02\x02\u05EA\u05E9\x03\x02\x02\x02\u05EA\u05EB\x03\x02" + "\x02\x02\u05EB\u05EC\x03\x02\x02\x02\u05EC\u05ED\x05V,\x02\u05ED\u05EE" + "\x07\xF0\x02\x02\u05EE\u05EF\x05\x84C\x02\u05EF\u060C\x03\x02\x02\x02" + "\u05F0\u05F1\x07\x93\x02\x02\u05F1\u05F3\x07\xD4\x02\x02\u05F2\u05F4\x07" + "\xA8\x02\x02\u05F3\u05F2\x03\x02\x02\x02\u05F3\u05F4\x03\x02\x02\x02\u05F4" + "\u05F5\x03\x02\x02\x02\u05F5\u05F6\x07\\\x02\x02\u05F6\u05F8\x05\u0178" + "\xBD\x02\u05F7\u05F9\x05\xECw\x02\u05F8\u05F7\x03\x02\x02\x02\u05F8\u05F9" + "\x03\x02\x02\x02\u05F9\u05FB\x03\x02\x02\x02\u05FA\u05FC\x05F$\x02\u05FB" + "\u05FA\x03\x02\x02\x02\u05FB\u05FC\x03\x02\x02\x02\u05FC\u060C\x03\x02" + "\x02\x02\u05FD\u05FE\x07\x93\x02\x02\u05FE\u0600\x07\xD4\x02\x02\u05FF" + "\u0601\x07\xA8\x02\x02\u0600\u05FF\x03\x02\x02\x02\u0600\u0601\x03\x02" + "\x02\x02\u0601\u0602\x03\x02\x02\x02\u0602\u0604\x07\\\x02\x02\u0603\u0605" + "\x05\u0178\xBD\x02\u0604\u0603\x03\x02\x02\x02\u0604\u0605\x03\x02\x02" + "\x02\u0605\u0606\x03\x02\x02\x02\u0606\u0609\x052\x1A\x02\u0607\u0608" + "\x07\xCB\x02\x02\u0608\u060A\x056\x1C\x02\u0609\u0607\x03\x02\x02\x02" + "\u0609\u060A\x03\x02\x02\x02\u060A\u060C\x03\x02\x02\x02\u060B\u05C5\x03" + "\x02\x02\x02\u060B\u05D6\x03\x02\x02\x02\u060B\u05E7\x03\x02\x02\x02\u060B" + "\u05F0\x03\x02\x02\x02\u060B\u05FD\x03\x02\x02\x02\u060C\x1F\x03\x02\x02" + "\x02\u060D\u060F\x05\"\x12\x02\u060E\u0610\x05\x18\r\x02\u060F\u060E\x03" + "\x02\x02\x02\u060F\u0610\x03\x02\x02\x02\u0610!\x03\x02\x02\x02\u0611" + "\u0612\x07\xD5\x02\x02\u0612\u0613\x07\x04\x02\x02\u0613\u0618\x05$\x13" + "\x02\u0614\u0615\x07\x06\x02\x02\u0615\u0617\x05$\x13\x02\u0616\u0614" + "\x03\x02\x02\x02\u0617\u061A\x03\x02\x02\x02\u0618\u0616\x03\x02\x02\x02" + "\u0618\u0619\x03\x02\x02\x02\u0619\u061B\x03\x02\x02\x02\u061A\u0618\x03" + "\x02\x02\x02\u061B\u061C\x07\x05\x02\x02\u061C#\x03\x02\x02\x02\u061D" + "\u0620\x05\u016C\xB7\x02\u061E\u061F\x07\u015A\x02\x02\u061F\u0621\x05" + "\u011A\x8E\x02\u0620\u061E\x03\x02\x02\x02\u0620\u0621\x03\x02\x02\x02" + "\u0621\u0627\x03\x02\x02\x02\u0622\u0623\x05\u016C\xB7\x02\u0623\u0624" + "\x07\u015A\x02\x02\u0624\u0625\x07T\x02\x02\u0625\u0627\x03\x02\x02\x02" + "\u0626\u061D\x03\x02\x02\x02\u0626\u0622\x03\x02\x02\x02\u0627%\x03\x02" + "\x02\x02\u0628\u0629\t\r\x02\x02\u0629\'\x03\x02\x02\x02\u062A\u062B\t" + "\x0E\x02\x02\u062B)\x03\x02\x02\x02\u062C\u0632\x05\\/\x02\u062D\u0632" + "\x05\u0178\xBD\x02\u062E\u0632\x05\u011C\x8F\x02\u062F\u0632\x05\u011E" + "\x90\x02\u0630\u0632\x05\u0120\x91\x02\u0631\u062C\x03\x02\x02\x02\u0631" + "\u062D\x03\x02\x02\x02\u0631\u062E\x03\x02\x02\x02\u0631\u062F\x03\x02" + "\x02\x02\u0631\u0630\x03\x02\x02\x02\u0632+\x03\x02\x02\x02\u0633\u0638" + "\x05\u016C\xB7\x02\u0634\u0635\x07\x07\x02\x02\u0635\u0637\x05\u016C\xB7" + "\x02\u0636\u0634\x03\x02\x02\x02\u0637\u063A\x03\x02\x02\x02\u0638\u0636" + "\x03\x02\x02\x02\u0638\u0639\x03\x02\x02\x02\u0639-\x03\x02\x02\x02\u063A" + "\u0638\x03\x02\x02\x02\u063B\u063C\x07\u0155\x02\x02\u063C\u0641\x050" + "\x19\x02\u063D\u063E\x07\x06\x02\x02\u063E\u0640\x050\x19\x02\u063F\u063D" + "\x03\x02\x02\x02\u0640\u0643\x03\x02\x02\x02\u0641\u063F\x03\x02\x02\x02" + "\u0641\u0642\x03\x02\x02\x02\u0642/\x03\x02\x02\x02\u0643\u0641\x03\x02" + "\x02\x02\u0644\u0646\x05\u0168\xB5\x02\u0645\u0647\x05\xCEh\x02\u0646" + "\u0645\x03\x02\x02\x02\u0646\u0647\x03\x02\x02\x02\u0647\u0649\x03\x02" + "\x02\x02\u0648\u064A\x07\x16\x02\x02\u0649\u0648\x03\x02\x02\x02\u0649" + "\u064A\x03\x02\x02\x02\u064A\u064B\x03\x02\x02\x02\u064B\u064C\x07\x04" + "\x02\x02\u064C\u064D\x05\x1C\x0F\x02\u064D\u064E\x07\x05\x02\x02\u064E" + "1\x03\x02\x02\x02\u064F\u0650\x07\u0147\x02\x02\u0650\u0651\x05\xF0y\x02" + "\u06513\x03\x02\x02\x02\u0652\u0653\x07\xCB\x02\x02\u0653\u0660\x05> " + "\x02\u0654\u0655\x07\xD6\x02\x02\u0655\u0656\x07!\x02\x02\u0656\u0660" + "\x05\xFE\x80\x02\u0657\u0660\x05\x16\f\x02\u0658\u0660\x05\x14\v\x02\u0659" + "\u0660\x05\xECw\x02\u065A\u0660\x05F$\x02\u065B\u0660\x05\x18\r\x02\u065C" + "\u0660\x05\x1A\x0E\x02\u065D\u065E\x07\u0124\x02\x02\u065E\u0660\x056" + "\x1C\x02\u065F\u0652\x03\x02\x02\x02\u065F\u0654\x03\x02\x02\x02\u065F" + "\u0657\x03\x02\x02\x02\u065F\u0658\x03\x02\x02\x02\u065F\u0659\x03\x02" + "\x02\x02\u065F\u065A\x03\x02\x02\x02\u065F\u065B\x03\x02\x02\x02\u065F" + "\u065C\x03\x02\x02\x02\u065F\u065D\x03\x02\x02\x02\u0660\u0663\x03\x02" + "\x02\x02\u0661\u065F\x03\x02\x02\x02\u0661\u0662\x03\x02\x02\x02\u0662" + "5\x03\x02\x02\x02\u0663\u0661\x03\x02\x02\x02\u0664\u0665\x07\x04\x02" + "\x02\u0665\u066A\x058\x1D\x02\u0666\u0667\x07\x06\x02\x02\u0667\u0669" + "\x058\x1D\x02\u0668\u0666\x03\x02\x02\x02\u0669\u066C\x03\x02\x02\x02" + "\u066A\u0668\x03\x02\x02\x02\u066A\u066B\x03\x02\x02\x02\u066B\u066D\x03" + "\x02\x02\x02\u066C\u066A\x03\x02\x02\x02\u066D\u066E\x07\x05\x02\x02\u066E" + "7\x03\x02\x02\x02\u066F\u0674\x05:\x1E\x02\u0670\u0672\x07\u015A\x02\x02" + "\u0671\u0670\x03\x02\x02\x02\u0671\u0672\x03\x02\x02\x02\u0672\u0673\x03" + "\x02\x02\x02\u0673\u0675\x05<\x1F\x02\u0674\u0671\x03\x02\x02\x02\u0674" + "\u0675\x03\x02\x02\x02\u06759\x03\x02\x02\x02\u0676\u067B\x05\u016C\xB7" + "\x02\u0677\u0678\x07\x07\x02\x02\u0678\u067A\x05\u016C\xB7\x02\u0679\u0677" + "\x03\x02\x02\x02\u067A\u067D\x03\x02\x02\x02\u067B\u0679\x03"; private static readonly _serializedATNSegment4: string = "\x02\x02\x02\u067B\u067C\x03\x02\x02\x02\u067C\u0680\x03\x02\x02\x02\u067D" + "\u067B\x03\x02\x02\x02\u067E\u0680\x05\u0178\xBD\x02\u067F\u0676\x03\x02" + "\x02\x02\u067F\u067E\x03\x02\x02\x02\u0680;\x03\x02\x02\x02\u0681\u0686" + "\x07\u0178\x02\x02\u0682\u0686\x07\u017A\x02\x02\u0683\u0686\x05\u0122" + "\x92\x02\u0684\u0686\x05\u0178\xBD\x02\u0685\u0681\x03\x02\x02\x02\u0685" + "\u0682\x03\x02\x02\x02\u0685\u0683\x03\x02\x02\x02\u0685\u0684\x03\x02" + "\x02\x02\u0686=\x03\x02\x02\x02\u0687\u0688\x07\x04\x02\x02\u0688\u068D" + "\x05@!\x02\u0689\u068A\x07\x06\x02\x02\u068A\u068C\x05@!\x02\u068B\u0689" + "\x03\x02\x02\x02\u068C\u068F\x03\x02\x02\x02\u068D\u068B\x03\x02\x02\x02" + "\u068D\u068E\x03\x02\x02\x02\u068E\u0690\x03\x02\x02\x02\u068F\u068D\x03" + "\x02\x02\x02\u0690\u0691\x07\x05\x02\x02\u0691?\x03\x02\x02\x02\u0692" + "\u0697\x05:\x1E\x02\u0693\u0695\x07\u015A\x02\x02\u0694\u0693\x03\x02" + "\x02\x02\u0694\u0695\x03\x02\x02\x02\u0695\u0696\x03\x02\x02\x02\u0696" + "\u0698\x05\u0106\x84\x02\u0697\u0694\x03\x02\x02\x02\u0697\u0698\x03\x02" + "\x02\x02\u0698A\x03\x02\x02\x02\u0699\u069A\x07\x04\x02\x02\u069A\u069F" + "\x05\u011A\x8E\x02\u069B\u069C\x07\x06\x02\x02\u069C\u069E\x05\u011A\x8E" + "\x02\u069D\u069B\x03\x02\x02\x02\u069E\u06A1\x03\x02\x02\x02\u069F\u069D" + "\x03\x02\x02\x02\u069F\u06A0\x03\x02\x02\x02\u06A0\u06A2\x03\x02\x02\x02" + "\u06A1\u069F\x03\x02\x02\x02\u06A2\u06A3\x07\x05\x02\x02\u06A3C\x03\x02" + "\x02\x02\u06A4\u06A5\x07\x04\x02\x02\u06A5\u06AA\x05B\"\x02\u06A6\u06A7" + "\x07\x06\x02\x02\u06A7\u06A9\x05B\"\x02\u06A8\u06A6\x03\x02\x02\x02\u06A9" + "\u06AC\x03\x02\x02\x02\u06AA\u06A8\x03\x02\x02\x02\u06AA\u06AB\x03\x02" + "\x02\x02\u06AB\u06AD\x03\x02\x02\x02\u06AC\u06AA\x03\x02\x02\x02\u06AD" + "\u06AE\x07\x05\x02\x02\u06AEE\x03\x02\x02\x02\u06AF\u06B0\x07\u0116\x02" + "\x02\u06B0\u06B1\x07\x16\x02\x02\u06B1\u06B6\x05H%\x02\u06B2\u06B3\x07" + "\u0116\x02\x02\u06B3\u06B4\x07!\x02\x02\u06B4\u06B6\x05J&\x02\u06B5\u06AF" + "\x03\x02\x02\x02\u06B5\u06B2\x03\x02\x02\x02\u06B6G\x03\x02\x02\x02\u06B7" + "\u06B8\x07\x92\x02\x02\u06B8\u06B9\x05\u0178\xBD\x02\u06B9\u06BA\x07\xD0" + "\x02\x02\u06BA\u06BB\x05\u0178\xBD\x02\u06BB\u06BE\x03\x02\x02\x02\u06BC" + "\u06BE\x05\u016C\xB7\x02\u06BD\u06B7\x03\x02\x02\x02\u06BD\u06BC\x03\x02" + "\x02\x02\u06BEI\x03\x02\x02\x02\u06BF\u06C3\x05\u0178\xBD\x02\u06C0\u06C1" + "\x07\u0155\x02\x02\u06C1\u06C2\x07\u0106\x02\x02\u06C2\u06C4\x056\x1C" + "\x02\u06C3\u06C0\x03\x02\x02\x02\u06C3\u06C4\x03\x02\x02\x02\u06C4K\x03" + "\x02\x02\x02\u06C5\u06C6\x05\u016C\xB7\x02\u06C6\u06C7\x05\u0178\xBD\x02" + "\u06C7M\x03\x02\x02\x02\u06C8\u06C9\x05\x1E\x10\x02\u06C9\u06CA\x05\x1C" + "\x0F\x02\u06CA\u0701\x03\x02\x02\x02\u06CB\u06CD\x05\x8CG\x02\u06CC\u06CE" + "\x05`1\x02\u06CD\u06CC\x03\x02\x02\x02\u06CE\u06CF\x03\x02\x02\x02\u06CF" + "\u06CD\x03\x02\x02\x02\u06CF\u06D0\x03\x02\x02\x02\u06D0\u0701\x03\x02" + "\x02\x02\u06D1\u06D2\x07V\x02\x02\u06D2\u06D3\x07{\x02\x02\u06D3\u06D4" + "\x05V,\x02\u06D4\u06D6\x05\xEAv\x02\u06D5\u06D7\x05\x84C\x02\u06D6\u06D5" + "\x03\x02\x02\x02\u06D6\u06D7\x03\x02\x02\x02\u06D7\u0701\x03\x02\x02\x02" + "\u06D8\u06D9\x07\u0144\x02\x02\u06D9\u06DA\x05V,\x02\u06DA\u06DB\x05\xEA" + "v\x02\u06DB\u06DD\x05r:\x02\u06DC\u06DE\x05\x84C\x02\u06DD\u06DC\x03\x02" + "\x02\x02\u06DD\u06DE\x03\x02\x02\x02\u06DE\u0701\x03\x02\x02\x02\u06DF" + "\u06E0\x07\xB1\x02\x02\u06E0\u06E1\x07\x98\x02\x02\u06E1\u06E2\x05V,\x02" + "\u06E2\u06E3\x05\xEAv\x02\u06E3\u06E9\x07\u0147\x02\x02\u06E4\u06EA\x05" + "\\/\x02\u06E5\u06E6\x07\x04\x02\x02\u06E6\u06E7\x05\x1C\x0F\x02\u06E7" + "\u06E8\x07\x05\x02\x02\u06E8\u06EA\x03\x02\x02\x02\u06E9\u06E4\x03\x02" + "\x02\x02\u06E9\u06E5\x03\x02\x02\x02\u06EA\u06EB\x03\x02\x02\x02\u06EB" + "\u06EC\x05\xEAv\x02\u06EC\u06ED\x07\xC8\x02\x02\u06ED\u06F1\x05\u010E" + "\x88\x02\u06EE\u06F0\x05t;\x02\u06EF\u06EE\x03\x02\x02\x02\u06F0\u06F3" + "\x03\x02\x02\x02\u06F1\u06EF\x03\x02\x02\x02\u06F1\u06F2\x03\x02\x02\x02" + "\u06F2\u06F7\x03\x02\x02\x02\u06F3\u06F1\x03\x02\x02\x02\u06F4\u06F6\x05" + "v<\x02\u06F5\u06F4\x03\x02\x02\x02\u06F6\u06F9\x03\x02\x02\x02\u06F7\u06F5" + "\x03\x02\x02\x02\u06F7\u06F8\x03\x02\x02\x02\u06F8\u06FD\x03\x02\x02\x02" + "\u06F9\u06F7\x03\x02\x02\x02\u06FA\u06FC\x05x=\x02\u06FB\u06FA\x03\x02" + "\x02\x02\u06FC\u06FF\x03\x02\x02\x02\u06FD\u06FB\x03\x02\x02\x02\u06FD" + "\u06FE\x03\x02\x02\x02\u06FE\u0701\x03\x02\x02\x02\u06FF\u06FD\x03\x02" + "\x02\x02\u0700\u06C8\x03\x02\x02\x02\u0700\u06CB\x03\x02\x02\x02\u0700" + "\u06D1\x03\x02\x02\x02\u0700\u06D8\x03\x02\x02\x02\u0700\u06DF\x03\x02" + "\x02\x02\u0701O\x03\x02\x02\x02\u0702\u0703\x05\\/\x02\u0703Q\x03\x02" + "\x02\x02\u0704\u0705\x05\\/\x02\u0705S\x03\x02\x02\x02\u0706\u0707\x05" + "\xF6|\x02\u0707U\x03\x02\x02\x02\u0708\u0709\x05\xF6|\x02\u0709W\x03\x02" + "\x02\x02\u070A\u070B\x05\xF8}\x02\u070BY\x03\x02\x02\x02\u070C\u070D\x05" + "\xF8}\x02\u070D[\x03\x02\x02\x02\u070E\u070F\x07\x88\x02\x02\u070F\u0710" + "\x07\x04\x02\x02\u0710\u0711\x05\u0106\x84\x02\u0711\u0712\x07\x05\x02" + "\x02\u0712\u0715\x03\x02\x02\x02\u0713\u0715\x05\xF0y\x02\u0714\u070E" + "\x03\x02\x02\x02\u0714\u0713\x03\x02\x02\x02\u0715]\x03\x02\x02\x02\u0716" + "\u0717\x07\xCD\x02\x02\u0717\u0718\x07!\x02\x02\u0718\u071D\x05f4\x02" + "\u0719\u071A\x07\x06\x02\x02\u071A\u071C\x05f4\x02\u071B\u0719\x03\x02" + "\x02\x02\u071C\u071F\x03\x02\x02\x02\u071D\u071B\x03\x02\x02\x02\u071D" + "\u071E\x03\x02\x02\x02\u071E\u0721\x03\x02\x02\x02\u071F\u071D\x03\x02" + "\x02\x02\u0720\u0716\x03\x02\x02\x02\u0720\u0721\x03\x02\x02\x02\u0721" + "\u072C\x03\x02\x02\x02\u0722\u0723\x07.\x02\x02\u0723\u0724\x07!\x02\x02" + "\u0724\u0729\x05\u0106\x84\x02\u0725\u0726\x07\x06\x02\x02\u0726\u0728" + "\x05\u0106\x84\x02\u0727\u0725\x03\x02\x02\x02\u0728\u072B\x03\x02\x02" + "\x02\u0729\u0727\x03\x02\x02\x02\u0729\u072A\x03\x02\x02\x02\u072A\u072D" + "\x03\x02\x02\x02\u072B\u0729\x03\x02\x02\x02\u072C\u0722\x03\x02\x02\x02" + "\u072C\u072D\x03\x02\x02\x02\u072D\u0738\x03\x02\x02\x02\u072E\u072F\x07" + "^\x02\x02\u072F\u0730\x07!\x02\x02\u0730\u0735\x05\u0106\x84\x02\u0731" + "\u0732\x07\x06\x02\x02\u0732\u0734\x05\u0106\x84\x02\u0733\u0731\x03\x02" + "\x02\x02\u0734\u0737\x03\x02\x02\x02\u0735\u0733\x03\x02\x02\x02\u0735" + "\u0736\x03\x02\x02\x02\u0736\u0739\x03\x02\x02\x02\u0737\u0735\x03\x02" + "\x02\x02\u0738\u072E\x03\x02\x02\x02\u0738\u0739\x03\x02\x02\x02\u0739" + "\u0744\x03\x02\x02\x02\u073A\u073B\x07\u0111\x02\x02\u073B\u073C\x07!" + "\x02\x02\u073C\u0741\x05f4\x02\u073D\u073E\x07\x06\x02\x02\u073E\u0740" + "\x05f4\x02\u073F\u073D\x03\x02\x02\x02\u0740\u0743\x03\x02\x02\x02\u0741" + "\u073F\x03\x02\x02\x02\u0741\u0742\x03\x02\x02\x02\u0742\u0745\x03\x02" + "\x02\x02\u0743\u0741\x03\x02\x02\x02\u0744\u073A\x03\x02\x02\x02\u0744" + "\u0745\x03\x02\x02\x02\u0745\u0747\x03\x02\x02\x02\u0746\u0748\x05\u0156" + "\xAC\x02\u0747\u0746\x03\x02\x02\x02\u0747\u0748\x03\x02\x02\x02\u0748" + "\u074E\x03\x02\x02\x02\u0749\u074C\x07\xA4\x02\x02\u074A\u074D\x07\f\x02" + "\x02\u074B\u074D\x05\u0106\x84\x02\u074C\u074A\x03\x02\x02\x02\u074C\u074B" + "\x03\x02\x02\x02\u074D\u074F\x03\x02\x02\x02\u074E\u0749\x03\x02\x02\x02" + "\u074E\u074F\x03\x02\x02\x02\u074F\u0752\x03\x02\x02\x02\u0750\u0751\x07" + "\xC7\x02\x02\u0751\u0753\x05\u0106\x84\x02\u0752\u0750\x03\x02\x02\x02" + "\u0752\u0753\x03\x02\x02\x02\u0753_\x03\x02\x02\x02\u0754\u0755\x05\x1E" + "\x10\x02\u0755\u0756\x05j6\x02\u0756a\x03\x02\x02\x02\u0757\u0758\b2\x01" + "\x02\u0758\u0759\x05d3\x02\u0759\u0771\x03\x02\x02\x02\u075A\u075B\f\x05" + "\x02\x02\u075B\u075C\x062\x03\x02\u075C\u075E\t\x0F\x02\x02\u075D\u075F" + "\x05\xBE`\x02\u075E\u075D\x03\x02\x02\x02\u075E\u075F\x03\x02\x02\x02" + "\u075F\u0760\x03\x02\x02\x02\u0760\u0770\x05b2\x06\u0761\u0762\f\x04\x02" + "\x02\u0762\u0763\x062\x05\x02\u0763\u0765\x07\x94\x02\x02\u0764\u0766" + "\x05\xBE`\x02\u0765\u0764\x03\x02\x02\x02\u0765\u0766\x03\x02\x02\x02" + "\u0766\u0767\x03\x02\x02\x02\u0767\u0770\x05b2\x05\u0768\u0769\f\x03\x02" + "\x02\u0769\u076A\x062\x07\x02\u076A\u076C\t\x10\x02\x02\u076B\u076D\x05" + "\xBE`\x02\u076C\u076B\x03\x02\x02\x02\u076C\u076D\x03\x02\x02\x02\u076D" + "\u076E\x03\x02\x02\x02\u076E\u0770\x05b2\x04\u076F\u075A\x03\x02\x02\x02" + "\u076F\u0761\x03\x02\x02\x02\u076F\u0768\x03\x02\x02\x02\u0770\u0773\x03" + "\x02\x02\x02\u0771\u076F\x03\x02\x02\x02\u0771\u0772\x03\x02\x02\x02\u0772" + "c\x03\x02\x02\x02\u0773\u0771\x03\x02\x02\x02\u0774\u077E\x05l7\x02\u0775" + "\u077E\x05h5\x02\u0776\u0777\x07\u0120\x02\x02\u0777\u077E\x05V,\x02\u0778" + "\u077E\x05\xDCo\x02\u0779\u077A\x07\x04\x02\x02\u077A\u077B\x05\x1C\x0F" + "\x02\u077B\u077C\x07\x05\x02\x02\u077C\u077E\x03\x02\x02\x02\u077D\u0774" + "\x03\x02\x02\x02\u077D\u0775\x03\x02\x02\x02\u077D\u0776\x03\x02\x02\x02" + "\u077D\u0778\x03\x02\x02\x02\u077D\u0779\x03\x02\x02\x02\u077Ee\x03\x02" + "\x02\x02\u077F\u0781\x05\u0106\x84\x02\u0780\u0782\t\x11\x02\x02\u0781" + "\u0780\x03\x02\x02\x02\u0781\u0782\x03\x02\x02\x02\u0782\u0785\x03\x02" + "\x02\x02\u0783\u0784\x07\xC4\x02\x02\u0784\u0786\t\x12\x02\x02\u0785\u0783" + "\x03\x02\x02\x02\u0785\u0786\x03\x02\x02\x02\u0786g\x03\x02\x02\x02\u0787" + "\u0789\x05\x8CG\x02\u0788\u078A\x05j6\x02\u0789\u0788\x03\x02\x02\x02" + "\u078A\u078B\x03\x02\x02\x02\u078B\u0789\x03\x02\x02\x02\u078B\u078C\x03" + "\x02\x02\x02\u078Ci\x03\x02\x02\x02\u078D\u078F\x05n8\x02\u078E\u0790" + "\x05\x84C\x02\u078F\u078E\x03\x02\x02\x02\u078F\u0790\x03\x02\x02\x02" + "\u0790\u0791\x03\x02\x02\x02\u0791\u0792\x05^0\x02\u0792\u07A9\x03\x02" + "\x02\x02\u0793\u0797\x05p9\x02\u0794\u0796\x05\xBC_\x02\u0795\u0794\x03" + "\x02\x02\x02\u0796\u0799\x03\x02\x02\x02\u0797\u0795\x03\x02\x02\x02\u0797" + "\u0798\x03\x02\x02\x02\u0798\u079B\x03\x02\x02\x02\u0799\u0797\x03\x02" + "\x02\x02\u079A\u079C\x05\x84C\x02\u079B\u079A\x03\x02\x02\x02\u079B\u079C" + "\x03\x02\x02\x02\u079C\u079E\x03\x02\x02\x02\u079D\u079F\x05\x92J\x02" + "\u079E\u079D\x03\x02\x02\x02\u079E\u079F\x03\x02\x02\x02\u079F\u07A1\x03" + "\x02\x02\x02\u07A0\u07A2\x05\x86D\x02\u07A1\u07A0\x03\x02\x02\x02\u07A1" + "\u07A2\x03\x02\x02\x02\u07A2\u07A4\x03\x02\x02\x02\u07A3\u07A5\x05\u0156" + "\xAC\x02\u07A4\u07A3\x03\x02\x02\x02\u07A4\u07A5\x03\x02\x02\x02\u07A5" + "\u07A6\x03\x02\x02\x02\u07A6\u07A7\x05^0\x02\u07A7\u07A9\x03\x02\x02\x02" + "\u07A8\u078D\x03\x02\x02\x02\u07A8\u0793\x03\x02\x02\x02\u07A9k\x03\x02" + "\x02\x02\u07AA\u07AC\x05n8\x02\u07AB\u07AD\x05\x8CG\x02\u07AC\u07AB\x03" + "\x02\x02\x02\u07AC\u07AD\x03\x02\x02\x02\u07AD\u07B1\x03\x02\x02\x02\u07AE" + "\u07B0\x05\xBC_\x02\u07AF\u07AE\x03\x02\x02\x02\u07B0\u07B3\x03\x02\x02" + "\x02\u07B1\u07AF\x03\x02\x02\x02\u07B1\u07B2\x03\x02\x02\x02\u07B2\u07B5" + "\x03\x02\x02\x02\u07B3\u07B1\x03\x02\x02\x02\u07B4\u07B6\x05\x84C\x02" + "\u07B5\u07B4\x03\x02\x02\x02\u07B5\u07B6\x03\x02\x02\x02\u07B6\u07B8\x03" + "\x02\x02\x02\u07B7\u07B9\x05\x92J\x02\u07B8\u07B7\x03\x02\x02\x02\u07B8" + "\u07B9\x03\x02\x02\x02\u07B9\u07BB\x03\x02\x02\x02\u07BA\u07BC\x05\x86" + "D\x02\u07BB\u07BA\x03\x02\x02\x02\u07BB\u07BC\x03\x02\x02\x02\u07BC\u07BE" + "\x03\x02\x02\x02\u07BD\u07BF\x05\u0156\xAC\x02\u07BE\u07BD\x03\x02\x02" + "\x02\u07BE\u07BF\x03\x02\x02\x02\u07BF\u07D7\x03\x02\x02\x02\u07C0\u07C2" + "\x05p9\x02\u07C1\u07C3\x05\x8CG\x02\u07C2\u07C1\x03\x02\x02\x02\u07C2" + "\u07C3\x03\x02\x02\x02\u07C3\u07C7\x03\x02\x02\x02\u07C4\u07C6\x05\xBC" + "_\x02\u07C5\u07C4\x03\x02\x02\x02\u07C6\u07C9\x03\x02\x02\x02\u07C7\u07C5" + "\x03\x02\x02\x02\u07C7\u07C8\x03\x02\x02\x02\u07C8\u07CB\x03\x02\x02\x02" + "\u07C9\u07C7\x03\x02\x02\x02\u07CA\u07CC\x05\x84C\x02\u07CB\u07CA\x03" + "\x02\x02\x02\u07CB\u07CC\x03\x02\x02\x02\u07CC\u07CE\x03\x02\x02\x02\u07CD" + "\u07CF\x05\x92J\x02\u07CE\u07CD\x03\x02\x02\x02\u07CE\u07CF\x03\x02\x02" + "\x02\u07CF\u07D1\x03\x02\x02\x02\u07D0\u07D2\x05\x86D\x02\u07D1\u07D0" + "\x03\x02\x02\x02\u07D1\u07D2\x03\x02\x02\x02\u07D2\u07D4\x03\x02\x02\x02" + "\u07D3\u07D5\x05\u0156\xAC\x02\u07D4\u07D3\x03\x02\x02\x02\u07D4\u07D5" + "\x03\x02\x02\x02\u07D5\u07D7\x03\x02\x02\x02\u07D6\u07AA\x03\x02\x02\x02" + "\u07D6\u07C0\x03\x02\x02\x02\u07D7m\x03\x02\x02\x02\u07D8\u07D9\x07\u0102" + "\x02\x02\u07D9\u07DA\x07\u0135\x02\x02\u07DA\u07DC\x07\x04\x02\x02\u07DB" + "\u07DD\x05\xBE`\x02\u07DC\u07DB\x03\x02\x02\x02\u07DC\u07DD\x03\x02\x02" + "\x02\u07DD\u07DE\x03\x02\x02\x02\u07DE\u07DF\x05\u010C\x87\x02\u07DF\u07E0" + "\x07\x05\x02\x02\u07E0\u07EC\x03\x02\x02\x02\u07E1\u07E3\x07\xAF\x02\x02" + "\u07E2\u07E4\x05\xBE`\x02\u07E3\u07E2\x03\x02\x02\x02\u07E3\u07E4\x03" + "\x02\x02\x02\u07E4\u07E5\x03\x02\x02\x02\u07E5\u07EC\x05\u010C\x87\x02" + "\u07E6\u07E8\x07\xEA\x02\x02\u07E7\u07E9\x05\xBE`\x02\u07E8\u07E7\x03" + "\x02\x02\x02\u07E8\u07E9\x03\x02\x02\x02\u07E9\u07EA\x03\x02\x02\x02\u07EA" + "\u07EC\x05\u010C\x87\x02\u07EB\u07D8\x03\x02\x02\x02\u07EB\u07E1\x03\x02" + "\x02\x02\u07EB\u07E6\x03\x02\x02\x02\u07EC\u07EE\x03\x02\x02\x02\u07ED" + "\u07EF\x05\xECw\x02\u07EE\u07ED\x03\x02\x02\x02\u07EE\u07EF\x03\x02\x02" + "\x02\u07EF\u07F2\x03\x02\x02\x02\u07F0\u07F1\x07\xE8\x02\x02\u07F1\u07F3" + "\x05\u0178\xBD\x02\u07F2\u07F0\x03\x02\x02\x02\u07F2\u07F3\x03\x02\x02" + "\x02\u07F3\u07F4\x03\x02\x02\x02\u07F4\u07F5\x07\u0147\x02\x02\u07F5\u0802" + "\x05\u0178\xBD\x02\u07F6\u0800\x07\x16\x02\x02\u07F7\u0801\x05\xD0i\x02" + "\u07F8\u0801\x05\u0144\xA3\x02\u07F9\u07FC\x07\x04\x02\x02\u07FA\u07FD" + "\x05\xD0i\x02\u07FB\u07FD\x05\u0144\xA3\x02\u07FC\u07FA\x03\x02\x02\x02" + "\u07FC\u07FB\x03\x02\x02\x02\u07FD\u07FE\x03\x02\x02\x02\u07FE\u07FF\x07" + "\x05\x02\x02\u07FF\u0801\x03\x02\x02\x02\u0800\u07F7\x03\x02\x02\x02\u0800" + "\u07F8\x03\x02\x02\x02\u0800\u07F9\x03\x02\x02\x02\u0801\u0803\x03\x02" + "\x02\x02\u0802\u07F6\x03\x02\x02\x02\u0802\u0803\x03\x02\x02\x02\u0803" + "\u0805\x03\x02\x02\x02\u0804\u0806\x05\xECw\x02\u0805\u0804\x03\x02\x02" + "\x02\u0805\u0806\x03\x02\x02\x02\u0806\u0809\x03\x02\x02\x02\u0807\u0808" + "\x07\xE7\x02\x02\u0808\u080A\x05\u0178\xBD\x02\u0809\u0807\x03\x02\x02" + "\x02\u0809\u080A\x03\x02\x02\x02\u080Ao\x03\x02\x02\x02\u080B\u080F\x07" + "\u0102\x02\x02\u080C\u080E\x05\x88E\x02\u080D\u080C\x03\x02\x02\x02\u080E" + "\u0811\x03\x02\x02\x02\u080F\u080D\x03\x02\x02\x02\u080F\u0810\x03\x02" + "\x02\x02\u0810\u0813\x03\x02\x02\x02\u0811\u080F\x03\x02\x02\x02\u0812" + "\u0814\x05\xBE`\x02\u0813\u0812\x03\x02\x02\x02\u0813\u0814\x03\x02\x02" + "\x02\u0814\u0815\x03\x02\x02\x02\u0815\u0816\x05\xFC\x7F\x02\u0816q\x03" + "\x02\x02\x02\u0817\u0818\x07\u0108\x02\x02\u0818\u0819\x05\x80A\x02\u0819" + "s\x03\x02\x02\x02\u081A\u081B\x07\u0152\x02\x02\u081B\u081E\x07\xB0\x02" + "\x02\u081C\u081D\x07\x10\x02\x02\u081D\u081F\x05\u010E\x88\x02\u081E\u081C" + "\x03\x02\x02\x02\u081E\u081F\x03\x02\x02\x02\u081F\u0820\x03\x02\x02\x02" + "\u0820\u0821\x07\u0127\x02\x02\u0821\u0822\x05z>\x02\u0822u\x03\x02\x02" + "\x02\u0823\u0824\x07\u0152\x02\x02\u0824\u0825\x07\xC2\x02\x02\u0825\u0828" + "\x07\xB0\x02\x02\u0826\u0827\x07!\x02\x02\u0827\u0829\x07\u0123\x02\x02" + "\u0828\u0826\x03\x02\x02\x02\u0828\u0829\x03\x02\x02\x02\u0829\u082C\x03" + "\x02\x02\x02\u082A\u082B\x07\x10\x02\x02\u082B\u082D\x05\u010E\x88\x02" + "\u082C\u082A\x03\x02\x02\x02\u082C\u082D\x03\x02\x02\x02\u082D\u082E\x03" + "\x02\x02\x02\u082E\u082F\x07\u0127\x02\x02\u082F\u0830\x05|?\x02\u0830" + "w\x03\x02\x02\x02\u0831\u0832\x07\u0152\x02\x02\u0832\u0833\x07\xC2\x02" + "\x02\u0833\u0834\x07\xB0\x02\x02\u0834\u0835\x07!\x02\x02\u0835\u0838" + "\x07\u0113\x02\x02\u0836\u0837\x07\x10\x02\x02\u0837\u0839\x05\u010E\x88" + "\x02\u0838\u0836\x03\x02\x02\x02\u0838\u0839\x03\x02\x02\x02\u0839\u083A" + "\x03\x02\x02\x02\u083A\u083B\x07\u0127\x02\x02\u083B\u083C\x05~@\x02\u083C" + "y\x03\x02\x02\x02\u083D\u0845\x07V\x02\x02\u083E\u083F\x07\u0144\x02\x02" + "\u083F\u0840\x07\u0108\x02\x02\u0840\u0845\x07\u0165\x02\x02\u0841\u0842" + "\x07\u0144\x02\x02\u0842\u0843\x07\u0108\x02\x02\u0843\u0845\x05\x80A" + "\x02\u0844\u083D\x03\x02\x02\x02\u0844\u083E\x03\x02\x02\x02\u0844\u0841" + "\x03\x02\x02\x02\u0845{\x03\x02\x02\x02\u0846\u0847\x07\x93\x02\x02\u0847" + "\u0859\x07\u0165\x02\x02\u0848\u0849\x07\x93\x02\x02\u0849\u084A\x07\x04" + "\x02\x02\u084A\u084B\x05\xEEx\x02\u084B\u084C\x07\x05\x02\x02\u084C\u084D" + "\x07\u0148\x02\x02\u084D\u084E\x07\x04\x02\x02\u084E\u0853\x05\u0106\x84" + "\x02\u084F\u0850\x07\x06\x02\x02\u0850\u0852\x05\u0106\x84\x02\u0851\u084F" + "\x03\x02\x02\x02\u0852\u0855\x03\x02\x02\x02\u0853\u0851\x03\x02\x02\x02" + "\u0853\u0854\x03\x02\x02\x02\u0854\u0856\x03\x02\x02\x02\u0855\u0853\x03" + "\x02\x02\x02\u0856\u0857\x07\x05\x02\x02\u0857\u0859\x03\x02\x02\x02\u0858" + "\u0846\x03\x02\x02\x02\u0858\u0848\x03\x02\x02\x02\u0859}\x03\x02\x02" + "\x02\u085A\u085F\x07V\x02\x02\u085B\u085C\x07\u0144\x02\x02\u085C\u085D" + "\x07\u0108\x02\x02\u085D\u085F\x05\x80A\x02\u085E\u085A\x03\x02\x02\x02" + "\u085E\u085B\x03\x02\x02\x02\u085F\x7F\x03\x02\x02\x02\u0860\u0865\x05" + "\x82B\x02\u0861\u0862\x07\x06\x02\x02\u0862\u0864\x05\x82B\x02\u0863\u0861" + "\x03\x02\x02\x02\u0864\u0867\x03\x02\x02\x02\u0865\u0863\x03\x02\x02\x02" + "\u0865\u0866\x03\x02\x02\x02\u0866\x81\x03\x02\x02\x02\u0867\u0865\x03" + "\x02\x02\x02\u0868\u0869\x05\xF0y\x02\u0869\u086A\x07\u015A\x02\x02\u086A" + "\u086B\x05\u0106\x84\x02\u086B\x83\x03\x02\x02\x02\u086C\u086D\x07\u0153" + "\x02\x02\u086D\u086E\x05\u010E\x88\x02\u086E\x85\x03\x02\x02\x02\u086F" + "\u0870\x07\x84\x02\x02\u0870\u0871\x05\u010E\x88\x02\u0871\x87\x03\x02" + "\x02\x02\u0872\u0873\x07\u0170\x02\x02\u0873\u087A\x05\x8AF\x02\u0874" + "\u0876\x07\x06\x02\x02\u0875\u0874\x03\x02\x02\x02\u0875\u0876\x03\x02" + "\x02\x02\u0876\u0877\x03\x02\x02\x02\u0877\u0879\x05\x8AF\x02\u0878\u0875" + "\x03\x02\x02\x02\u0879\u087C\x03\x02\x02\x02\u087A\u0878\x03\x02\x02\x02" + "\u087A\u087B\x03\x02\x02\x02\u087B\u087D\x03\x02\x02\x02\u087C\u087A\x03" + "\x02\x02\x02\u087D\u087E\x07\u0171\x02\x02\u087E\x89\x03\x02\x02\x02\u087F" + "\u088D\x05\u016C\xB7\x02\u0880\u0881\x05\u016C\xB7\x02\u0881\u0882\x07" + "\x04\x02\x02\u0882\u0887\x05\u0116\x8C\x02\u0883\u0884\x07\x06\x02\x02" + "\u0884\u0886\x05\u0116\x8C\x02\u0885\u0883\x03\x02\x02\x02\u0886\u0889" + "\x03\x02\x02\x02\u0887\u0885\x03\x02\x02\x02\u0887\u0888\x03\x02\x02\x02" + "\u0888\u088A\x03\x02\x02\x02\u0889\u0887\x03\x02\x02\x02\u088A\u088B\x07" + "\x05\x02\x02\u088B\u088D\x03\x02\x02\x02\u088C\u087F\x03\x02\x02\x02\u088C" + "\u0880\x03\x02\x02\x02\u088D\x8B\x03\x02\x02\x02\u088E\u088F\x07{\x02" + "\x02\u088F\u0894\x05\xC0a\x02\u0890\u0891\x07\x06\x02\x02\u0891\u0893" + "\x05\xC0a\x02\u0892\u0890\x03\x02\x02\x02\u0893\u0896\x03\x02\x02\x02" + "\u0894\u0892\x03\x02\x02\x02\u0894\u0895\x03\x02\x02\x02\u0895\u089A\x03" + "\x02\x02\x02\u0896\u0894\x03\x02\x02\x02\u0897\u0899\x05\xBC_\x02\u0898" + "\u0897\x03\x02\x02\x02\u0899\u089C\x03\x02\x02\x02\u089A\u0898\x03\x02" + "\x02\x02\u089A\u089B\x03\x02\x02\x02\u089B\u089E\x03\x02\x02\x02\u089C" + "\u089A\x03\x02\x02\x02\u089D\u089F\x05\x9CO\x02\u089E\u089D\x03\x02\x02" + "\x02\u089E\u089F\x03\x02\x02\x02\u089F\u08A1\x03\x02\x02\x02\u08A0\u08A2" + "\x05\xA2R\x02\u08A1\u08A0\x03\x02\x02\x02\u08A1\u08A2\x03\x02\x02\x02" + "\u08A2\x8D\x03\x02\x02\x02\u08A3\u08A4\t\x13\x02\x02\u08A4\x8F\x03\x02" + "\x02\x02\u08A5\u08A7\x07w\x02\x02\u08A6\u08A5\x03\x02\x02\x02\u08A6\u08A7" + "\x03\x02\x02\x02\u08A7\u08A8\x03\x02\x02\x02\u08A8\u08A9\t\x14\x02\x02" + "\u08A9\u08AA\x07\x16\x02\x02\u08AA\u08AB\x07\xC6\x02\x02\u08AB\u08B4\x05" + "\u017C\xBF\x02\u08AC\u08AE\x07w\x02\x02\u08AD\u08AC\x03\x02\x02\x02\u08AD" + "\u08AE\x03\x02\x02\x02\u08AE\u08AF\x03\x02\x02\x02\u08AF\u08B0\t\x15\x02" + "\x02\u08B0\u08B1\x07\x16\x02\x02\u08B1\u08B2\x07\xC6\x02\x02\u08B2\u08B4" + "\x05\u0112\x8A\x02\u08B3\u08A6\x03\x02\x02\x02\u08B3\u08AD\x03\x02\x02" + "\x02\u08B4\x91\x03\x02\x02\x02\u08B5\u08B6\x07\x82\x02\x02\u08B6\u08B7" + "\x07!\x02\x02\u08B7\u08BC\x05\x94K\x02\u08B8\u08B9\x07\x06\x02\x02\u08B9" + "\u08BB\x05\x94K\x02\u08BA\u08B8\x03\x02\x02\x02\u08BB\u08BE\x03\x02\x02" + "\x02\u08BC\u08BA\x03\x02\x02\x02\u08BC\u08BD\x03\x02\x02\x02\u08BD\u08DD" + "\x03\x02\x02\x02\u08BE\u08BC\x03\x02\x02\x02\u08BF\u08C0\x07\x82\x02\x02" + "\u08C0\u08C1\x07!\x02\x02\u08C1\u08C6\x05\u0106\x84\x02\u08C2\u08C3\x07" + "\x06\x02\x02\u08C3\u08C5\x05\u0106\x84\x02\u08C4\u08C2\x03\x02\x02\x02" + "\u08C5\u08C8\x03\x02\x02\x02\u08C6\u08C4\x03\x02\x02\x02\u08C6\u08C7\x03" + "\x02\x02\x02\u08C7\u08DA\x03\x02\x02\x02\u08C8\u08C6\x03\x02\x02\x02\u08C9" + "\u08CA\x07\u0155\x02\x02\u08CA\u08DB\x07\xFB\x02\x02\u08CB\u08CC\x07\u0155" + "\x02\x02\u08CC\u08DB\x07?\x02\x02\u08CD\u08CE\x07\x83\x02\x02\u08CE\u08CF" + "\x07\u010A\x02\x02\u08CF\u08D0\x07\x04\x02\x02\u08D0\u08D5\x05\x9AN\x02" + "\u08D1\u08D2\x07\x06\x02\x02\u08D2\u08D4\x05\x9AN\x02\u08D3\u08D1\x03" + "\x02\x02\x02\u08D4\u08D7\x03\x02\x02\x02\u08D5\u08D3\x03\x02\x02\x02\u08D5" + "\u08D6\x03\x02\x02\x02\u08D6\u08D8\x03\x02\x02\x02\u08D7\u08D5\x03\x02" + "\x02\x02\u08D8\u08D9\x07\x05\x02\x02\u08D9\u08DB\x03\x02\x02\x02\u08DA" + "\u08C9\x03\x02\x02\x02\u08DA\u08CB\x03\x02\x02\x02\u08DA\u08CD\x03\x02" + "\x02\x02\u08DA\u08DB\x03\x02\x02\x02\u08DB\u08DD\x03\x02\x02\x02\u08DC" + "\u08B5\x03\x02\x02\x02\u08DC\u08BF\x03\x02\x02\x02\u08DD\x93\x03\x02\x02" + "\x02\u08DE\u08E1\x05\x96L\x02\u08DF\u08E1\x05\u0106\x84\x02\u08E0\u08DE" + "\x03\x02\x02\x02\u08E0\u08DF\x03\x02\x02\x02\u08E1\x95\x03\x02\x02\x02" + "\u08E2\u08E3\t\x16\x02\x02\u08E3\u08E4\x07\x04\x02\x02\u08E4\u08E9\x05" + "\x9AN\x02\u08E5\u08E6\x07\x06\x02\x02\u08E6\u08E8\x05\x9AN\x02\u08E7\u08E5" + "\x03\x02\x02\x02\u08E8\u08EB\x03\x02\x02\x02\u08E9\u08E7\x03\x02\x02\x02" + "\u08E9\u08EA\x03\x02\x02\x02\u08EA\u08EC\x03\x02\x02\x02\u08EB\u08E9\x03" + "\x02\x02\x02\u08EC\u08ED\x07\x05\x02\x02\u08ED\u08FC\x03\x02\x02\x02\u08EE" + "\u08EF\x07\x83\x02\x02\u08EF\u08F0\x07\u010A\x02\x02\u08F0\u08F1\x07\x04" + "\x02\x02\u08F1\u08F6\x05\x98M\x02\u08F2\u08F3\x07\x06\x02\x02\u08F3\u08F5" + "\x05\x98M\x02\u08F4\u08F2\x03\x02\x02\x02\u08F5\u08F8\x03\x02\x02\x02" + "\u08F6\u08F4\x03\x02\x02\x02\u08F6\u08F7\x03\x02\x02\x02\u08F7\u08F9\x03" + "\x02\x02\x02\u08F8\u08F6\x03\x02\x02\x02\u08F9\u08FA\x07\x05\x02\x02\u08FA" + "\u08FC\x03\x02\x02\x02\u08FB\u08E2\x03\x02\x02\x02\u08FB\u08EE\x03\x02" + "\x02\x02\u08FC\x97\x03\x02\x02\x02\u08FD\u0900\x05\x96L\x02\u08FE\u0900" + "\x05\x9AN\x02\u08FF\u08FD\x03\x02\x02\x02\u08FF\u08FE\x03\x02\x02\x02" + "\u0900\x99\x03\x02\x02\x02\u0901\u090A\x07\x04\x02\x02\u0902\u0907\x05" + "\u0106\x84\x02\u0903\u0904\x07\x06\x02\x02\u0904\u0906\x05\u0106\x84\x02" + "\u0905\u0903\x03\x02\x02\x02\u0906\u0909\x03\x02\x02\x02\u0907\u0905\x03" + "\x02\x02\x02\u0907\u0908\x03\x02\x02\x02\u0908\u090B\x03\x02\x02\x02\u0909" + "\u0907\x03\x02\x02\x02\u090A\u0902\x03\x02\x02\x02\u090A\u090B\x03\x02" + "\x02\x02\u090B\u090C\x03\x02\x02\x02\u090C\u090F\x07\x05\x02\x02\u090D" + "\u090F\x05\u0106\x84\x02\u090E\u0901\x03\x02\x02\x02\u090E\u090D\x03\x02" + "\x02\x02\u090F\x9B\x03\x02\x02\x02\u0910\u0911\x07\xDB\x02\x02\u0911\u0912" + "\x07\x04\x02\x02\u0912\u0913\x05\xFC\x7F\x02\u0913\u0914\x07w\x02\x02" + "\u0914\u0915\x05\x9EP\x02\u0915\u0916\x07\x8C\x02\x02\u0916\u0917\x07" + "\x04\x02\x02\u0917\u091C\x05\xA0Q\x02\u0918\u0919\x07\x06\x02\x02\u0919" + "\u091B\x05\xA0Q\x02\u091A\u0918\x03\x02\x02\x02\u091B\u091E\x03\x02\x02" + "\x02\u091C\u091A\x03\x02\x02\x02\u091C\u091D\x03\x02\x02\x02\u091D\u091F" + "\x03\x02\x02\x02\u091E\u091C\x03\x02\x02\x02\u091F\u0920\x07\x05\x02\x02" + "\u0920\u0921\x07\x05\x02\x02\u0921\x9D\x03\x02\x02\x02\u0922\u092F\x05" + "\u016C\xB7\x02\u0923\u0924\x07\x04\x02\x02\u0924\u0929\x05\u016C\xB7\x02" + "\u0925\u0926\x07\x06\x02\x02\u0926\u0928\x05\u016C\xB7\x02\u0927\u0925" + "\x03\x02\x02\x02\u0928\u092B\x03\x02\x02\x02\u0929\u0927\x03\x02\x02\x02" + "\u0929\u092A\x03\x02\x02\x02\u092A\u092C\x03\x02\x02\x02\u092B\u0929\x03" + "\x02\x02\x02\u092C\u092D\x07\x05\x02\x02\u092D\u092F\x03\x02\x02\x02\u092E" + "\u0922\x03\x02\x02\x02\u092E\u0923\x03\x02\x02\x02\u092F\x9F\x03\x02\x02" + "\x02\u0930\u0935\x05\u0106\x84\x02\u0931\u0933\x07\x16\x02\x02\u0932\u0931" + "\x03\x02\x02\x02\u0932\u0933\x03\x02\x02\x02\u0933\u0934\x03\x02\x02\x02" + "\u0934\u0936\x05\u016C\xB7\x02\u0935\u0932\x03\x02\x02\x02\u0935\u0936" + "\x03\x02\x02\x02\u0936\xA1\x03\x02\x02\x02\u0937\u0939\x07\u0142\x02\x02" + "\u0938\u093A\x05\xA4S\x02\u0939\u0938\x03\x02\x02\x02\u0939\u093A\x03" + "\x02\x02\x02\u093A\u093B\x03\x02\x02\x02\u093B\u093C\x07\x04\x02\x02\u093C" + "\u093D\x05\xA6T\x02\u093D\u0942\x07\x05\x02"; private static readonly _serializedATNSegment5: string = "\x02\u093E\u0940\x07\x16\x02\x02\u093F\u093E\x03\x02\x02\x02\u093F\u0940" + "\x03\x02\x02\x02\u0940\u0941\x03\x02\x02\x02\u0941\u0943\x05\u016C\xB7" + "\x02\u0942\u093F\x03\x02\x02\x02\u0942\u0943\x03\x02\x02\x02\u0943\xA3" + "\x03\x02\x02\x02\u0944\u0945\t\x17\x02\x02\u0945\u0946\x07\xC4\x02\x02" + "\u0946\xA5\x03\x02\x02\x02\u0947\u094A\x05\xA8U\x02\u0948\u094A\x05\xAA" + "V\x02\u0949\u0947\x03\x02\x02\x02\u0949\u0948\x03\x02\x02\x02\u094A\xA7" + "\x03\x02\x02\x02\u094B\u094C\x05\xAEX\x02\u094C\u094D\x07w\x02\x02\u094D" + "\u094E\x05\xB0Y\x02\u094E\u094F\x07\x8C\x02\x02\u094F\u0950\x07\x04\x02" + "\x02\u0950\u0955\x05\xB2Z\x02\u0951\u0952\x07\x06\x02\x02\u0952\u0954" + "\x05\xB2Z\x02\u0953\u0951\x03\x02\x02\x02\u0954\u0957\x03\x02\x02\x02" + "\u0955\u0953\x03\x02\x02\x02\u0955\u0956\x03\x02\x02\x02\u0956\u0958\x03" + "\x02\x02\x02\u0957\u0955\x03\x02\x02\x02\u0958\u0959\x07\x05\x02\x02\u0959" + "\xA9\x03\x02\x02\x02\u095A\u095B\x07\x04\x02\x02\u095B\u0960\x05\xAEX" + "\x02\u095C\u095D\x07\x06\x02\x02\u095D\u095F\x05\xAEX\x02\u095E\u095C" + "\x03\x02\x02\x02\u095F\u0962\x03\x02\x02\x02\u0960\u095E\x03\x02\x02\x02" + "\u0960\u0961\x03\x02\x02\x02\u0961\u0963\x03\x02\x02\x02\u0962\u0960\x03" + "\x02\x02\x02\u0963\u0964\x07\x05\x02\x02\u0964\u0965\x07w\x02\x02\u0965" + "\u0966\x05\xB0Y\x02\u0966\u0967\x07\x8C\x02\x02\u0967\u0968\x07\x04\x02" + "\x02\u0968\u096D\x05\xACW\x02\u0969\u096A\x07\x06\x02\x02\u096A\u096C" + "\x05\xACW\x02\u096B\u0969\x03\x02\x02\x02\u096C\u096F\x03\x02\x02\x02" + "\u096D\u096B\x03\x02\x02\x02\u096D\u096E\x03\x02\x02\x02\u096E\u0970\x03" + "\x02\x02\x02\u096F\u096D\x03\x02\x02\x02\u0970\u0971\x07\x05\x02\x02\u0971" + "\xAB\x03\x02\x02\x02\u0972\u0973\x07\x04\x02\x02\u0973\u0978\x05\xB4[" + "\x02\u0974\u0975\x07\x06\x02\x02\u0975\u0977\x05\xB4[\x02\u0976\u0974" + "\x03\x02\x02\x02\u0977\u097A\x03\x02\x02\x02\u0978\u0976\x03\x02\x02\x02" + "\u0978\u0979\x03\x02\x02\x02\u0979\u097B\x03\x02\x02\x02\u097A\u0978\x03" + "\x02\x02\x02\u097B\u097D\x07\x05\x02\x02\u097C\u097E\x05\xB6\\\x02\u097D" + "\u097C\x03\x02\x02\x02\u097D\u097E\x03\x02\x02\x02\u097E\xAD\x03\x02\x02" + "\x02\u097F\u0980\x05\u016C\xB7\x02\u0980\xAF\x03\x02\x02\x02\u0981\u0982" + "\x05\u016C\xB7\x02\u0982\xB1\x03\x02\x02\x02\u0983\u0985\x05\xB4[\x02" + "\u0984\u0986\x05\xB6\\\x02\u0985\u0984\x03\x02\x02\x02\u0985\u0986\x03" + "\x02\x02\x02\u0986\xB3\x03\x02\x02\x02\u0987\u0988\x05\xF0y\x02\u0988" + "\xB5\x03\x02\x02\x02\u0989\u098B\x07\x16\x02\x02\u098A\u0989\x03\x02\x02" + "\x02\u098A\u098B\x03\x02\x02\x02\u098B\u098C\x03\x02\x02\x02\u098C\u098D" + "\x05\u016C\xB7\x02\u098D\xB7\x03\x02\x02\x02\u098E\u098F\x07\x89\x02\x02" + "\u098F\u0990\x07\xC2\x02\x02\u0990\u0991\x07i\x02\x02\u0991\xB9\x03\x02" + "\x02\x02\u0992\u0993\x07\x89\x02\x02\u0993\u0994\x07i\x02\x02\u0994\xBB" + "\x03\x02\x02\x02\u0995\u0996\x07\x9E\x02\x02\u0996\u0998\x07\u014D\x02" + "\x02\u0997\u0999\x07\xCF\x02\x02\u0998\u0997\x03\x02\x02\x02\u0998\u0999" + "\x03\x02\x02\x02\u0999\u099A\x03\x02\x02\x02\u099A\u099B\x05Z.\x02\u099B" + "\u09A4\x07\x04\x02\x02\u099C\u09A1\x05\u0106\x84\x02\u099D\u099E\x07\x06" + "\x02\x02\u099E\u09A0\x05\u0106\x84\x02\u099F\u099D\x03\x02\x02\x02\u09A0" + "\u09A3\x03\x02\x02\x02\u09A1\u099F\x03\x02\x02\x02\u09A1\u09A2\x03\x02" + "\x02\x02\u09A2\u09A5\x03\x02\x02\x02\u09A3\u09A1\x03\x02\x02\x02\u09A4" + "\u099C\x03\x02\x02\x02\u09A4\u09A5\x03\x02\x02\x02\u09A5\u09A6\x03\x02" + "\x02\x02\u09A6\u09A7\x07\x05\x02\x02\u09A7\u09B3\x05\xEAv\x02\u09A8\u09AA" + "\x07\x16\x02\x02\u09A9\u09A8\x03\x02\x02\x02\u09A9\u09AA\x03\x02\x02\x02" + "\u09AA\u09AB\x03\x02\x02\x02\u09AB\u09B0\x05\u016C\xB7\x02\u09AC\u09AD" + "\x07\x06\x02\x02\u09AD\u09AF\x05\u016C\xB7\x02\u09AE\u09AC\x03\x02\x02" + "\x02\u09AF\u09B2\x03\x02\x02\x02\u09B0\u09AE\x03\x02\x02\x02\u09B0\u09B1" + "\x03\x02\x02\x02\u09B1\u09B4\x03\x02\x02\x02\u09B2\u09B0\x03\x02\x02\x02" + "\u09B3\u09A9\x03\x02\x02\x02\u09B3\u09B4\x03\x02\x02\x02\u09B4\xBD\x03" + "\x02\x02\x02\u09B5\u09B6\t\x18\x02\x02\u09B6\xBF\x03\x02\x02\x02\u09B7" + "\u09B9\x07\x9E\x02\x02\u09B8\u09B7\x03\x02\x02\x02\u09B8\u09B9\x03\x02" + "\x02\x02\u09B9\u09BA\x03\x02\x02\x02\u09BA\u09BE\x05\xDAn\x02\u09BB\u09BD" + "\x05\xC2b\x02\u09BC\u09BB\x03\x02\x02\x02\u09BD\u09C0\x03\x02\x02\x02" + "\u09BE\u09BC\x03\x02\x02\x02\u09BE\u09BF\x03\x02\x02\x02\u09BF\u09C3\x03" + "\x02\x02\x02\u09C0\u09BE\x03\x02\x02\x02\u09C1\u09C3\x05V,\x02\u09C2\u09B8" + "\x03\x02\x02\x02\u09C2\u09C1\x03\x02\x02\x02\u09C3\xC1\x03\x02\x02\x02" + "\u09C4\u09C8\x05\xC4c\x02\u09C5\u09C8\x05\x9CO\x02\u09C6\u09C8\x05\xA2" + "R\x02\u09C7\u09C4\x03\x02\x02\x02\u09C7\u09C5\x03\x02\x02\x02\u09C7\u09C6" + "\x03\x02\x02\x02\u09C8\xC3\x03\x02\x02\x02\u09C9\u09CA\x05\xC6d\x02\u09CA" + "\u09CC\x07\x9B\x02\x02\u09CB\u09CD\x07\x9E\x02\x02\u09CC\u09CB\x03\x02" + "\x02\x02\u09CC\u09CD\x03\x02\x02\x02\u09CD\u09CE\x03\x02\x02\x02\u09CE" + "\u09D0\x05\xDAn\x02\u09CF\u09D1\x05\xC8e\x02\u09D0\u09CF\x03\x02\x02\x02" + "\u09D0\u09D1\x03\x02\x02\x02\u09D1\u09DB\x03\x02\x02\x02\u09D2\u09D3\x07" + "\xC0\x02\x02\u09D3\u09D4\x05\xC6d\x02\u09D4\u09D6\x07\x9B\x02\x02\u09D5" + "\u09D7\x07\x9E\x02\x02\u09D6\u09D5\x03\x02\x02\x02\u09D6\u09D7\x03\x02" + "\x02\x02\u09D7\u09D8\x03\x02\x02\x02\u09D8\u09D9\x05\xDAn\x02\u09D9\u09DB" + "\x03\x02\x02\x02\u09DA\u09C9\x03\x02\x02\x02\u09DA\u09D2\x03\x02\x02\x02" + "\u09DB\xC5\x03\x02\x02\x02\u09DC\u09DE\x07\x90\x02\x02\u09DD\u09DC\x03" + "\x02\x02\x02\u09DD\u09DE\x03\x02\x02\x02\u09DE\u09F5\x03\x02\x02\x02\u09DF" + "\u09F5\x07>\x02\x02\u09E0\u09E2\x07\xA1\x02\x02\u09E1\u09E3\x07\xCF\x02" + "\x02\u09E2\u09E1\x03\x02\x02\x02\u09E2\u09E3\x03\x02\x02\x02\u09E3\u09F5" + "\x03\x02\x02\x02\u09E4\u09E6\x07\xA1\x02\x02\u09E5\u09E4\x03\x02\x02\x02" + "\u09E5\u09E6\x03\x02\x02\x02\u09E6\u09E7\x03\x02\x02\x02\u09E7\u09F5\x07" + "\u0103\x02\x02\u09E8\u09EA\x07\xF5\x02\x02\u09E9\u09EB\x07\xCF\x02\x02" + "\u09EA\u09E9\x03\x02\x02\x02\u09EA\u09EB\x03\x02\x02\x02\u09EB\u09F5\x03" + "\x02\x02\x02\u09EC\u09EE\x07|\x02\x02\u09ED\u09EF\x07\xCF\x02\x02\u09EE" + "\u09ED\x03\x02\x02\x02\u09EE\u09EF\x03\x02\x02\x02\u09EF\u09F5\x03\x02" + "\x02\x02\u09F0\u09F2\x07\xA1\x02\x02\u09F1\u09F0\x03\x02\x02\x02\u09F1" + "\u09F2\x03\x02\x02\x02\u09F2\u09F3\x03\x02\x02\x02\u09F3\u09F5\x07\x11" + "\x02\x02\u09F4\u09DD\x03\x02\x02\x02\u09F4\u09DF\x03\x02\x02\x02\u09F4" + "\u09E0\x03\x02\x02\x02\u09F4\u09E5\x03\x02\x02\x02\u09F4\u09E8\x03\x02" + "\x02\x02\u09F4\u09EC\x03\x02\x02\x02\u09F4\u09F1\x03\x02\x02\x02\u09F5" + "\xC7\x03\x02\x02\x02\u09F6\u09F7\x07\xC8\x02\x02\u09F7\u09FB\x05\u010E" + "\x88\x02\u09F8\u09F9\x07\u0147\x02\x02\u09F9\u09FB\x05\xCEh\x02\u09FA" + "\u09F6\x03\x02\x02\x02\u09FA\u09F8\x03\x02\x02\x02\u09FB\xC9\x03\x02\x02" + "\x02\u09FC\u09FD\x07\u0122\x02\x02\u09FD\u09FF\x07\x04\x02\x02\u09FE\u0A00" + "\x05\xCCg\x02\u09FF\u09FE\x03\x02\x02\x02\u09FF\u0A00\x03\x02\x02\x02" + "\u0A00\u0A01\x03\x02\x02\x02\u0A01\u0A06\x07\x05\x02\x02\u0A02\u0A03\x07" + "\xEF\x02\x02\u0A03\u0A04\x07\x04\x02\x02\u0A04\u0A05\x07\u0178\x02\x02" + "\u0A05\u0A07\x07\x05\x02\x02\u0A06\u0A02\x03\x02\x02\x02\u0A06\u0A07\x03" + "\x02\x02\x02\u0A07\xCB\x03\x02\x02\x02\u0A08\u0A0A\x07\u0164\x02\x02\u0A09" + "\u0A08\x03\x02\x02\x02\u0A09\u0A0A\x03\x02\x02\x02\u0A0A\u0A0B\x03\x02" + "\x02\x02\u0A0B\u0A0C\t\x19\x02\x02\u0A0C\u0A21\x07\xDA\x02\x02\u0A0D\u0A0E" + "\x05\u0106\x84\x02\u0A0E\u0A0F\x07\xFD\x02\x02\u0A0F\u0A21\x03\x02\x02" + "\x02\u0A10\u0A11\x07\x1F\x02\x02\u0A11\u0A12\x07\u0178\x02\x02\u0A12\u0A13" + "\x07\xCE\x02\x02\u0A13\u0A14\x07\xC6\x02\x02\u0A14\u0A1D\x07\u0178\x02" + "\x02\u0A15\u0A1B\x07\xC8\x02\x02\u0A16\u0A1C\x05\u016C\xB7\x02\u0A17\u0A18" + "\x05\u0166\xB4\x02\u0A18\u0A19\x07\x04\x02\x02\u0A19\u0A1A\x07\x05\x02" + "\x02\u0A1A\u0A1C\x03\x02\x02\x02\u0A1B\u0A16\x03\x02\x02\x02\u0A1B\u0A17" + "\x03\x02\x02\x02\u0A1C\u0A1E\x03\x02\x02\x02\u0A1D\u0A15\x03\x02\x02\x02" + "\u0A1D\u0A1E\x03\x02\x02\x02\u0A1E\u0A21\x03\x02\x02\x02\u0A1F\u0A21\x05" + "\u0106\x84\x02\u0A20\u0A09\x03\x02\x02\x02\u0A20\u0A0D\x03\x02\x02\x02" + "\u0A20\u0A10\x03\x02\x02\x02\u0A20\u0A1F\x03\x02\x02\x02\u0A21\xCD\x03" + "\x02\x02\x02\u0A22\u0A23\x07\x04\x02\x02\u0A23\u0A24\x05\xD0i\x02\u0A24" + "\u0A25\x07\x05\x02\x02\u0A25\xCF\x03\x02\x02\x02\u0A26\u0A2B\x05\u0168" + "\xB5\x02\u0A27\u0A28\x07\x06\x02\x02\u0A28\u0A2A\x05\u0168\xB5\x02\u0A29" + "\u0A27\x03\x02\x02\x02\u0A2A\u0A2D\x03\x02\x02\x02\u0A2B\u0A29\x03\x02" + "\x02\x02\u0A2B\u0A2C\x03\x02\x02\x02\u0A2C\xD1\x03\x02\x02\x02\u0A2D\u0A2B" + "\x03\x02\x02\x02\u0A2E\u0A2F\x07\x04\x02\x02\u0A2F\u0A34\x05\xD4k\x02" + "\u0A30\u0A31\x07\x06\x02\x02\u0A31\u0A33\x05\xD4k\x02\u0A32\u0A30\x03" + "\x02\x02\x02\u0A33\u0A36\x03\x02\x02\x02\u0A34\u0A32\x03\x02\x02\x02\u0A34" + "\u0A35\x03\x02\x02\x02\u0A35\u0A37\x03\x02\x02\x02\u0A36\u0A34\x03\x02" + "\x02\x02\u0A37\u0A38\x07\x05\x02\x02\u0A38\xD3\x03\x02\x02\x02\u0A39\u0A3B" + "\x05\u0168\xB5\x02\u0A3A\u0A3C\t\x11\x02\x02\u0A3B\u0A3A\x03\x02\x02\x02" + "\u0A3B\u0A3C\x03\x02\x02\x02\u0A3C\xD5\x03\x02\x02\x02\u0A3D\u0A3E\x07" + "\x04\x02\x02\u0A3E\u0A43\x05\xD8m\x02\u0A3F\u0A40\x07\x06\x02\x02\u0A40" + "\u0A42\x05\xD8m\x02\u0A41\u0A3F\x03\x02\x02\x02\u0A42\u0A45\x03\x02\x02" + "\x02\u0A43\u0A41\x03\x02\x02\x02\u0A43\u0A44\x03\x02\x02\x02\u0A44\u0A46" + "\x03\x02\x02\x02\u0A45\u0A43\x03\x02\x02\x02\u0A46\u0A47\x07\x05\x02\x02" + "\u0A47\xD7\x03\x02\x02\x02\u0A48\u0A4A\x05\u016C\xB7\x02\u0A49\u0A4B\x05" + "\x1A\x0E\x02\u0A4A\u0A49\x03\x02\x02\x02\u0A4A\u0A4B\x03\x02\x02\x02\u0A4B" + "\xD9\x03\x02\x02\x02\u0A4C\u0A4E\x05\\/\x02\u0A4D\u0A4F\x05\x90I\x02\u0A4E" + "\u0A4D\x03\x02\x02\x02\u0A4E\u0A4F\x03\x02\x02\x02\u0A4F\u0A51\x03\x02" + "\x02\x02\u0A50\u0A52\x05\xCAf\x02\u0A51\u0A50\x03\x02\x02\x02\u0A51\u0A52" + "\x03\x02\x02\x02\u0A52\u0A53\x03\x02\x02\x02\u0A53\u0A54\x05\xEAv\x02" + "\u0A54\u0A68\x03\x02\x02\x02\u0A55\u0A56\x07\x04\x02\x02\u0A56\u0A57\x05" + "\x1C\x0F\x02\u0A57\u0A59\x07\x05\x02\x02\u0A58\u0A5A\x05\xCAf\x02\u0A59" + "\u0A58\x03\x02\x02\x02\u0A59\u0A5A\x03\x02\x02\x02\u0A5A\u0A5B\x03\x02" + "\x02\x02\u0A5B\u0A5C\x05\xEAv\x02\u0A5C\u0A68\x03\x02\x02\x02\u0A5D\u0A5E" + "\x07\x04\x02\x02\u0A5E\u0A5F\x05\xC0a\x02\u0A5F\u0A61\x07\x05\x02\x02" + "\u0A60\u0A62\x05\xCAf\x02\u0A61\u0A60\x03\x02\x02\x02\u0A61\u0A62\x03" + "\x02\x02\x02\u0A62\u0A63\x03\x02\x02\x02\u0A63\u0A64\x05\xEAv\x02\u0A64" + "\u0A68\x03\x02\x02\x02\u0A65\u0A68\x05\xDCo\x02\u0A66\u0A68\x05\xE8u\x02" + "\u0A67\u0A4C\x03\x02\x02\x02\u0A67\u0A55\x03\x02\x02\x02\u0A67\u0A5D\x03" + "\x02\x02\x02\u0A67\u0A65\x03\x02\x02\x02\u0A67\u0A66\x03\x02\x02\x02\u0A68" + "\xDB\x03\x02\x02\x02\u0A69\u0A6A\x07\u0148\x02\x02\u0A6A\u0A6F\x05\u0106" + "\x84\x02\u0A6B\u0A6C\x07\x06\x02\x02\u0A6C\u0A6E\x05\u0106\x84\x02\u0A6D" + "\u0A6B\x03\x02\x02\x02\u0A6E\u0A71\x03\x02\x02\x02\u0A6F\u0A6D\x03\x02" + "\x02\x02\u0A6F\u0A70\x03\x02\x02\x02\u0A70\u0A72\x03\x02\x02\x02\u0A71" + "\u0A6F\x03\x02\x02\x02\u0A72\u0A73\x05\xEAv\x02\u0A73\xDD\x03\x02\x02" + "\x02\u0A74\u0A75\x07\u0120\x02\x02\u0A75\u0A77\x05V,\x02\u0A76\u0A78\x05" + "\xE0q\x02\u0A77\u0A76\x03\x02\x02\x02\u0A77\u0A78\x03\x02\x02\x02\u0A78" + "\u0A88\x03\x02\x02\x02\u0A79\u0A7A\x07\u0120\x02\x02\u0A7A\u0A7B\x07\x04" + "\x02\x02\u0A7B\u0A7C\x05V,\x02\u0A7C\u0A7E\x07\x05\x02\x02\u0A7D\u0A7F" + "\x05\xE0q\x02\u0A7E\u0A7D\x03\x02\x02\x02\u0A7E\u0A7F\x03\x02\x02\x02" + "\u0A7F\u0A88\x03\x02\x02\x02\u0A80\u0A81\x07\u0120\x02\x02\u0A81\u0A82" + "\x07\x04\x02\x02\u0A82\u0A83\x05\x1C\x0F\x02\u0A83\u0A85\x07\x05\x02\x02" + "\u0A84\u0A86\x05\xE0q\x02\u0A85\u0A84\x03\x02\x02\x02\u0A85\u0A86\x03" + "\x02\x02\x02\u0A86\u0A88\x03\x02\x02\x02\u0A87\u0A74\x03\x02\x02\x02\u0A87" + "\u0A79\x03\x02\x02\x02\u0A87\u0A80\x03\x02\x02\x02\u0A88\xDF\x03\x02\x02" + "\x02\u0A89\u0A8A\x07\u0155\x02\x02\u0A8A\u0A8B\x07\u010D\x02\x02\u0A8B" + "\u0A9D\x07\xD5\x02\x02\u0A8C\u0A8D\t\x1A\x02\x02\u0A8D\u0A9A\x07!\x02" + "\x02\u0A8E\u0A8F\x07\x04\x02\x02\u0A8F\u0A94\x05\u0106\x84\x02\u0A90\u0A91" + "\x07\x06\x02\x02\u0A91\u0A93\x05\u0106\x84\x02\u0A92\u0A90\x03\x02\x02" + "\x02\u0A93\u0A96\x03\x02\x02\x02\u0A94\u0A92\x03\x02\x02\x02\u0A94\u0A95" + "\x03\x02\x02\x02\u0A95\u0A97\x03\x02\x02\x02\u0A96\u0A94\x03\x02\x02\x02" + "\u0A97\u0A98\x07\x05\x02\x02\u0A98\u0A9B\x03\x02\x02\x02\u0A99\u0A9B\x05" + "\u0106\x84\x02\u0A9A\u0A8E\x03\x02\x02\x02\u0A9A\u0A99\x03\x02\x02\x02" + "\u0A9B\u0A9D\x03\x02\x02\x02\u0A9C\u0A89\x03\x02\x02\x02\u0A9C\u0A8C\x03" + "\x02\x02\x02\u0A9D\u0AAE\x03\x02\x02\x02\u0A9E\u0A9F\t\x1B\x02\x02\u0A9F" + "\u0AAC\x07!\x02\x02\u0AA0\u0AA1\x07\x04\x02\x02\u0AA1\u0AA6\x05f4\x02" + "\u0AA2\u0AA3\x07\x06\x02\x02\u0AA3\u0AA5\x05f4\x02\u0AA4\u0AA2\x03\x02" + "\x02\x02\u0AA5\u0AA8\x03\x02\x02\x02\u0AA6\u0AA4\x03\x02\x02\x02\u0AA6" + "\u0AA7\x03\x02\x02\x02\u0AA7\u0AA9\x03\x02\x02\x02\u0AA8\u0AA6\x03\x02" + "\x02\x02\u0AA9\u0AAA\x07\x05\x02\x02\u0AAA\u0AAD\x03\x02\x02\x02\u0AAB" + "\u0AAD\x05f4\x02\u0AAC\u0AA0\x03\x02\x02\x02\u0AAC\u0AAB\x03\x02\x02\x02" + "\u0AAD\u0AAF\x03\x02\x02\x02\u0AAE\u0A9E\x03\x02\x02\x02\u0AAE\u0AAF\x03" + "\x02\x02\x02\u0AAF\xE1\x03\x02\x02\x02\u0AB0\u0AB1\x05\u016C\xB7\x02\u0AB1" + "\u0AB2\x07\u016F\x02\x02\u0AB2\u0AB3\x05\xDEp\x02\u0AB3\xE3\x03\x02\x02" + "\x02\u0AB4\u0AB7\x05\xDEp\x02\u0AB5\u0AB7\x05\xE2r\x02\u0AB6\u0AB4\x03" + "\x02\x02\x02\u0AB6\u0AB5\x03\x02\x02\x02\u0AB7\xE5\x03\x02\x02\x02\u0AB8" + "\u0ABB\x05\xE4s\x02\u0AB9\u0ABB\x05\u010A\x86\x02\u0ABA\u0AB8\x03\x02" + "\x02\x02\u0ABA\u0AB9\x03\x02\x02\x02\u0ABB\xE7\x03\x02\x02\x02\u0ABC\u0ABD" + "\x05\u0162\xB2\x02\u0ABD\u0AC6\x07\x04\x02\x02\u0ABE\u0AC3\x05\xE6t\x02" + "\u0ABF\u0AC0\x07\x06\x02\x02\u0AC0\u0AC2\x05\xE6t\x02\u0AC1\u0ABF\x03" + "\x02\x02\x02\u0AC2\u0AC5\x03\x02\x02\x02\u0AC3\u0AC1\x03\x02\x02\x02\u0AC3" + "\u0AC4\x03\x02\x02\x02\u0AC4\u0AC7\x03\x02\x02\x02\u0AC5\u0AC3\x03\x02" + "\x02\x02\u0AC6\u0ABE\x03\x02\x02\x02\u0AC6\u0AC7\x03\x02\x02\x02\u0AC7" + "\u0AC8\x03\x02\x02\x02\u0AC8\u0AC9\x07\x05\x02\x02\u0AC9\u0ACA\x05\xEA" + "v\x02\u0ACA\xE9\x03\x02\x02\x02\u0ACB\u0ACD\x07\x16\x02\x02\u0ACC\u0ACB" + "\x03\x02\x02\x02\u0ACC\u0ACD\x03\x02\x02\x02\u0ACD\u0ACE\x03\x02\x02\x02" + "\u0ACE\u0AD0\x05\u016E\xB8\x02\u0ACF\u0AD1\x05\xCEh\x02\u0AD0\u0ACF\x03" + "\x02\x02\x02\u0AD0\u0AD1\x03\x02\x02\x02\u0AD1\u0AD3\x03\x02\x02\x02\u0AD2" + "\u0ACC\x03\x02\x02\x02\u0AD2\u0AD3\x03\x02\x02\x02\u0AD3\xEB\x03\x02\x02" + "\x02\u0AD4\u0AD5\x07\xFC\x02\x02\u0AD5\u0AD6\x07y\x02\x02\u0AD6\u0AD7" + "\x07\u0105\x02\x02\u0AD7\u0ADB\x05\u0178\xBD\x02\u0AD8\u0AD9\x07\u0155" + "\x02\x02\u0AD9\u0ADA\x07\u0106\x02\x02\u0ADA\u0ADC\x056\x1C\x02\u0ADB" + "\u0AD8\x03\x02\x02\x02\u0ADB\u0ADC\x03\x02\x02\x02\u0ADC\u0B06\x03\x02" + "\x02\x02\u0ADD\u0ADE\x07\xFC\x02\x02\u0ADE\u0ADF\x07y\x02\x02\u0ADF\u0AE9" + "\x07W\x02\x02\u0AE0\u0AE1\x07q\x02\x02\u0AE1\u0AE2\x07\u0126\x02\x02\u0AE2" + "\u0AE3\x07!\x02\x02\u0AE3\u0AE7\x05\u0178\xBD\x02\u0AE4\u0AE5\x07e\x02" + "\x02\u0AE5\u0AE6\x07!\x02\x02\u0AE6\u0AE8\x05\u0178\xBD\x02\u0AE7\u0AE4" + "\x03\x02\x02\x02\u0AE7\u0AE8\x03\x02\x02\x02\u0AE8\u0AEA\x03\x02\x02\x02" + "\u0AE9\u0AE0\x03\x02\x02\x02\u0AE9\u0AEA\x03\x02\x02\x02\u0AEA\u0AF0\x03" + "\x02\x02\x02\u0AEB\u0AEC\x072\x02\x02\u0AEC\u0AED\x07\x9A\x02\x02\u0AED" + "\u0AEE\x07\u0126\x02\x02\u0AEE\u0AEF\x07!\x02\x02\u0AEF\u0AF1\x05\u0178" + "\xBD\x02\u0AF0\u0AEB\x03\x02\x02\x02\u0AF0\u0AF1\x03\x02\x02\x02\u0AF1" + "\u0AF7\x03\x02\x02\x02\u0AF2\u0AF3\x07\xAF\x02\x02\u0AF3\u0AF4\x07\x9C" + "\x02\x02\u0AF4\u0AF5\x07\u0126\x02\x02\u0AF5\u0AF6\x07!\x02\x02\u0AF6" + "\u0AF8\x05\u0178\xBD\x02\u0AF7\u0AF2\x03\x02\x02\x02\u0AF7\u0AF8\x03\x02" + "\x02\x02\u0AF8\u0AFD\x03\x02\x02\x02\u0AF9\u0AFA\x07\xA5\x02\x02\u0AFA" + "\u0AFB\x07\u0126\x02\x02\u0AFB\u0AFC\x07!\x02\x02\u0AFC\u0AFE\x05\u0178" + "\xBD\x02\u0AFD\u0AF9\x03\x02\x02\x02\u0AFD\u0AFE\x03\x02\x02\x02\u0AFE" + "\u0B03\x03\x02\x02\x02\u0AFF\u0B00\x07\xC3\x02\x02\u0B00\u0B01\x07U\x02" + "\x02\u0B01\u0B02\x07\x16\x02\x02\u0B02\u0B04\x05\u0178\xBD\x02\u0B03\u0AFF" + "\x03\x02\x02\x02\u0B03\u0B04\x03\x02\x02\x02\u0B04\u0B06\x03\x02\x02\x02" + "\u0B05\u0AD4\x03\x02\x02\x02\u0B05\u0ADD\x03\x02\x02\x02\u0B06\xED\x03" + "\x02\x02\x02\u0B07\u0B0C\x05\xF0y\x02\u0B08\u0B09\x07\x06\x02\x02\u0B09" + "\u0B0B\x05\xF0y\x02\u0B0A\u0B08\x03\x02\x02\x02\u0B0B\u0B0E\x03\x02\x02" + "\x02\u0B0C\u0B0A\x03\x02\x02\x02\u0B0C\u0B0D\x03\x02\x02\x02\u0B0D\xEF" + "\x03\x02\x02\x02\u0B0E\u0B0C\x03\x02\x02\x02\u0B0F\u0B14\x05\u0168\xB5" + "\x02\u0B10\u0B11\x07\x07\x02\x02\u0B11\u0B13\x05\u0168\xB5\x02\u0B12\u0B10" + "\x03\x02\x02\x02\u0B13\u0B16\x03\x02\x02\x02\u0B14\u0B12\x03\x02\x02\x02" + "\u0B14\u0B15\x03\x02\x02\x02\u0B15\xF1\x03\x02\x02\x02\u0B16\u0B14\x03" + "\x02\x02\x02\u0B17\u0B1C\x05\xF4{\x02\u0B18\u0B19\x07\x06\x02\x02\u0B19" + "\u0B1B\x05\xF4{\x02\u0B1A\u0B18\x03\x02\x02\x02\u0B1B\u0B1E\x03\x02\x02" + "\x02\u0B1C\u0B1A\x03\x02\x02\x02\u0B1C\u0B1D\x03\x02\x02\x02\u0B1D\xF3" + "\x03\x02\x02\x02\u0B1E\u0B1C\x03\x02\x02\x02\u0B1F\u0B22\x05\xF0y\x02" + "\u0B20\u0B21\x07\xCB\x02\x02\u0B21\u0B23\x056\x1C\x02\u0B22\u0B20\x03" + "\x02\x02\x02\u0B22\u0B23\x03\x02\x02\x02\u0B23\xF5\x03\x02\x02\x02\u0B24" + "\u0B25\x05\u0168\xB5\x02\u0B25\u0B26\x07\x07\x02\x02\u0B26\u0B28\x03\x02" + "\x02\x02\u0B27\u0B24\x03\x02\x02\x02\u0B27\u0B28\x03\x02\x02\x02\u0B28" + "\u0B29\x03\x02\x02\x02\u0B29\u0B2A\x05\u0168\xB5\x02\u0B2A\xF7\x03\x02" + "\x02\x02\u0B2B\u0B2C\x05\u0168\xB5\x02\u0B2C\u0B2D\x07\x07\x02\x02\u0B2D" + "\u0B2F\x03\x02\x02\x02\u0B2E\u0B2B\x03\x02\x02\x02\u0B2E\u0B2F\x03\x02" + "\x02\x02\u0B2F\u0B30\x03\x02\x02\x02\u0B30\u0B31\x05\u0168\xB5\x02\u0B31" + "\xF9\x03\x02\x02\x02\u0B32\u0B3A\x05\u0106\x84\x02\u0B33\u0B35\x07\x16" + "\x02\x02\u0B34\u0B33\x03\x02\x02\x02\u0B34\u0B35\x03\x02\x02\x02\u0B35" + "\u0B38\x03\x02\x02\x02\u0B36\u0B39\x05\u0168\xB5\x02\u0B37\u0B39\x05\xCE" + "h\x02\u0B38\u0B36\x03\x02\x02\x02\u0B38\u0B37\x03\x02\x02\x02\u0B39\u0B3B" + "\x03\x02\x02\x02\u0B3A\u0B34\x03\x02\x02\x02\u0B3A\u0B3B\x03\x02\x02\x02" + "\u0B3B\xFB\x03\x02\x02\x02\u0B3C\u0B41\x05\xFA~\x02\u0B3D\u0B3E\x07\x06" + "\x02\x02\u0B3E\u0B40\x05\xFA~\x02\u0B3F\u0B3D\x03\x02\x02\x02\u0B40\u0B43" + "\x03\x02\x02\x02\u0B41\u0B3F\x03\x02\x02\x02\u0B41\u0B42\x03\x02\x02\x02" + "\u0B42\xFD\x03\x02\x02\x02\u0B43\u0B41\x03\x02\x02\x02\u0B44\u0B45\x07" + "\x04\x02\x02\u0B45\u0B4A\x05\u0100\x81\x02\u0B46\u0B47\x07\x06\x02\x02" + "\u0B47\u0B49\x05\u0100\x81\x02\u0B48\u0B46\x03\x02\x02\x02\u0B49\u0B4C" + "\x03\x02\x02\x02\u0B4A\u0B48\x03\x02\x02\x02\u0B4A\u0B4B\x03\x02\x02\x02" + "\u0B4B\u0B4D\x03\x02\x02\x02\u0B4C\u0B4A\x03\x02\x02\x02\u0B4D\u0B4E\x07" + "\x05\x02\x02\u0B4E\xFF\x03\x02\x02\x02\u0B4F\u0B52\x05\u0102\x82\x02\u0B50" + "\u0B52\x05\u0146\xA4\x02\u0B51\u0B4F\x03\x02\x02\x02\u0B51\u0B50\x03\x02" + "\x02\x02\u0B52\u0101\x03\x02\x02\x02\u0B53\u0B61\x05\u0166\xB4\x02\u0B54" + "\u0B55\x05\u016C\xB7\x02\u0B55\u0B56\x07\x04\x02\x02\u0B56\u0B5B\x05\u0104" + "\x83\x02\u0B57\u0B58\x07\x06\x02\x02\u0B58\u0B5A\x05\u0104\x83\x02\u0B59" + "\u0B57\x03\x02\x02\x02\u0B5A\u0B5D\x03\x02\x02\x02\u0B5B\u0B59\x03\x02" + "\x02\x02\u0B5B\u0B5C\x03\x02\x02\x02\u0B5C\u0B5E\x03\x02\x02\x02\u0B5D" + "\u0B5B\x03\x02\x02\x02\u0B5E\u0B5F\x07\x05\x02\x02\u0B5F\u0B61\x03\x02" + "\x02\x02\u0B60\u0B53\x03\x02\x02\x02\u0B60\u0B54\x03\x02\x02\x02\u0B61" + "\u0103\x03\x02\x02\x02\u0B62\u0B65\x05\u0166\xB4\x02\u0B63\u0B65\x05\u011A" + "\x8E\x02\u0B64\u0B62\x03\x02\x02\x02\u0B64\u0B63\x03\x02\x02\x02\u0B65" + "\u0105\x03\x02\x02\x02\u0B66\u0B67\x05\u010E\x88\x02\u0B67\u0107\x03\x02" + "\x02\x02\u0B68\u0B69\x05\u016C\xB7\x02\u0B69\u0B6A\x07\u016F\x02\x02\u0B6A" + "\u0B6B\x05\u0106\x84\x02\u0B6B\u0109\x03\x02\x02\x02\u0B6C\u0B6F\x05\u0106" + "\x84\x02\u0B6D\u0B6F\x05\u0108\x85\x02\u0B6E\u0B6C\x03\x02\x02\x02\u0B6E" + "\u0B6D\x03\x02\x02\x02\u0B6F\u010B\x03\x02\x02\x02\u0B70\u0B75\x05\u0106" + "\x84\x02\u0B71\u0B72\x07\x06\x02\x02\u0B72\u0B74\x05\u0106\x84\x02\u0B73" + "\u0B71\x03\x02\x02\x02\u0B74\u0B77\x03\x02\x02\x02\u0B75\u0B73\x03\x02" + "\x02\x02\u0B75\u0B76\x03\x02\x02\x02\u0B76\u010D\x03\x02\x02\x02\u0B77" + "\u0B75\x03\x02\x02\x02\u0B78\u0B79\b\x88\x01\x02\u0B79\u0B7A\t\x1C\x02" + "\x02\u0B7A\u0B85\x05\u010E\x88\x07\u0B7B\u0B7C\x07i\x02\x02\u0B7C\u0B7D" + "\x07\x04\x02\x02\u0B7D\u0B7E\x05\x1C\x0F\x02\u0B7E\u0B7F\x07\x05\x02\x02" + "\u0B7F\u0B85\x03\x02\x02\x02\u0B80\u0B82\x05\u0112\x8A\x02\u0B81\u0B83" + "\x05\u0110\x89\x02\u0B82\u0B81\x03\x02\x02\x02\u0B82\u0B83\x03\x02\x02" + "\x02\u0B83\u0B85\x03\x02\x02\x02\u0B84\u0B78\x03\x02\x02\x02\u0B84\u0B7B" + "\x03\x02\x02\x02\u0B84\u0B80\x03\x02\x02\x02\u0B85\u0B8E\x03\x02\x02\x02" + "\u0B86\u0B87\f\x04\x02\x02\u0B87\u0B88\x07\x10\x02\x02\u0B88\u0B8D\x05" + "\u010E\x88\x05\u0B89\u0B8A\f\x03\x02\x02\u0B8A\u0B8B\x07\xCC\x02\x02\u0B8B" + "\u0B8D\x05\u010E\x88\x04\u0B8C\u0B86\x03\x02\x02\x02\u0B8C\u0B89\x03\x02" + "\x02\x02\u0B8D\u0B90\x03\x02\x02\x02\u0B8E\u0B8C\x03\x02\x02\x02\u0B8E" + "\u0B8F\x03\x02\x02\x02\u0B8F\u010F\x03\x02\x02\x02\u0B90\u0B8E\x03\x02" + "\x02\x02\u0B91\u0B93\x07\xC2\x02\x02\u0B92\u0B91\x03\x02\x02\x02\u0B92" + "\u0B93\x03\x02\x02\x02\u0B93\u0B94\x03\x02\x02\x02\u0B94\u0B95\x07\x1A" + "\x02\x02\u0B95\u0B96\x05\u0112\x8A\x02\u0B96\u0B97\x07\x10\x02\x02\u0B97" + "\u0B98\x05\u0112\x8A\x02\u0B98\u0BE4\x03\x02\x02\x02\u0B99\u0B9B\x07\xC2" + "\x02\x02\u0B9A\u0B99\x03\x02\x02\x02\u0B9A\u0B9B\x03\x02\x02\x02\u0B9B" + "\u0B9C\x03\x02\x02\x02\u0B9C\u0B9D\x07\x8C\x02\x02\u0B9D\u0B9E\x07\x04" + "\x02\x02\u0B9E\u0BA3\x05\u0106\x84\x02\u0B9F\u0BA0\x07\x06\x02\x02\u0BA0" + "\u0BA2\x05\u0106\x84\x02\u0BA1\u0B9F\x03\x02\x02\x02\u0BA2\u0BA5\x03\x02" + "\x02\x02\u0BA3\u0BA1\x03\x02\x02\x02\u0BA3\u0BA4\x03\x02\x02\x02\u0BA4" + "\u0BA6\x03\x02\x02\x02\u0BA5\u0BA3\x03\x02\x02\x02\u0BA6\u0BA7\x07\x05" + "\x02\x02\u0BA7\u0BE4\x03\x02\x02\x02\u0BA8\u0BAA\x07\xC2\x02\x02\u0BA9" + "\u0BA8\x03\x02\x02\x02\u0BA9\u0BAA\x03\x02\x02\x02\u0BAA\u0BAB\x03\x02" + "\x02\x02\u0BAB\u0BAC\x07\x8C\x02\x02\u0BAC\u0BAD\x07\x04\x02\x02\u0BAD" + "\u0BAE\x05\x1C\x0F\x02\u0BAE\u0BAF\x07\x05\x02\x02\u0BAF\u0BE4\x03\x02" + "\x02\x02\u0BB0\u0BB2\x07\xC2\x02\x02\u0BB1\u0BB0\x03\x02\x02\x02\u0BB1" + "\u0BB2\x03\x02\x02\x02\u0BB2\u0BB3\x03\x02\x02\x02\u0BB3\u0BB4\t\x1D\x02" + "\x02\u0BB4\u0BE4\x05\u0112\x8A\x02\u0BB5\u0BB7\x07\xC2\x02\x02\u0BB6\u0BB5" + "\x03\x02\x02\x02\u0BB6\u0BB7\x03\x02\x02\x02\u0BB7\u0BB8\x03\x02\x02\x02" + "\u0BB8\u0BB9\t\x1E\x02\x02\u0BB9\u0BC7\t\x1F\x02\x02\u0BBA\u0BBB\x07\x04" + "\x02\x02\u0BBB\u0BC8\x07\x05\x02\x02\u0BBC\u0BBD\x07\x04\x02\x02\u0BBD" + "\u0BC2\x05\u0106\x84\x02\u0BBE\u0BBF\x07\x06\x02\x02\u0BBF\u0BC1\x05\u0106" + "\x84\x02\u0BC0\u0BBE\x03\x02\x02\x02\u0BC1\u0BC4\x03\x02\x02\x02\u0BC2" + "\u0BC0\x03\x02\x02\x02\u0BC2\u0BC3\x03\x02\x02\x02\u0BC3\u0BC5\x03\x02" + "\x02\x02\u0BC4\u0BC2\x03\x02\x02\x02\u0BC5\u0BC6\x07\x05\x02\x02\u0BC6" + "\u0BC8\x03\x02\x02\x02\u0BC7\u0BBA\x03\x02\x02\x02\u0BC7\u0BBC\x03\x02" + "\x02\x02\u0BC8\u0BE4\x03\x02\x02\x02\u0BC9\u0BCB\x07\xC2\x02\x02\u0BCA" + "\u0BC9\x03\x02\x02\x02\u0BCA\u0BCB\x03\x02\x02\x02\u0BCB\u0BCC\x03\x02" + "\x02\x02\u0BCC\u0BCD\t\x1E\x02\x02\u0BCD\u0BD0\x05\u0112\x8A\x02\u0BCE" + "\u0BCF\x07d\x02\x02\u0BCF\u0BD1\x05\u0178\xBD\x02\u0BD0\u0BCE\x03\x02" + "\x02\x02\u0BD0\u0BD1\x03\x02\x02\x02\u0BD1\u0BE4\x03\x02\x02\x02\u0BD2" + "\u0BD4\x07\x99\x02\x02\u0BD3\u0BD5\x07\xC2\x02\x02\u0BD4\u0BD3\x03\x02" + "\x02\x02\u0BD4\u0BD5\x03\x02\x02\x02\u0BD5\u0BD6\x03\x02\x02\x02\u0BD6" + "\u0BE4\x07\xC3\x02\x02\u0BD7\u0BD9\x07\x99\x02\x02\u0BD8\u0BDA\x07\xC2" + "\x02\x02\u0BD9\u0BD8\x03\x02\x02\x02\u0BD9\u0BDA\x03\x02\x02\x02\u0BDA" + "\u0BDB\x03\x02\x02\x02\u0BDB\u0BE4\t \x02\x02\u0BDC\u0BDE\x07\x99\x02" + "\x02\u0BDD\u0BDF\x07\xC2\x02\x02\u0BDE\u0BDD\x03\x02\x02\x02\u0BDE\u0BDF" + "\x03\x02\x02\x02\u0BDF\u0BE0\x03\x02\x02\x02\u0BE0\u0BE1\x07]\x02\x02" + "\u0BE1\u0BE2\x07{\x02\x02\u0BE2\u0BE4\x05\u0112\x8A\x02\u0BE3\u0B92\x03" + "\x02\x02\x02\u0BE3\u0B9A\x03\x02\x02\x02\u0BE3\u0BA9\x03\x02\x02\x02\u0BE3" + "\u0BB1\x03\x02\x02\x02\u0BE3\u0BB6\x03\x02\x02\x02\u0BE3\u0BCA\x03\x02" + "\x02\x02\u0BE3\u0BD2\x03\x02\x02\x02\u0BE3\u0BD7\x03\x02\x02\x02\u0BE3" + "\u0BDC\x03\x02\x02\x02\u0BE4\u0111\x03\x02\x02\x02\u0BE5\u0BE6\b\x8A\x01" + "\x02\u0BE6\u0BEA\x05\u0116\x8C\x02\u0BE7\u0BE8\t!\x02\x02\u0BE8\u0BEA" + "\x05\u0112\x8A\t\u0BE9\u0BE5\x03\x02\x02\x02\u0BE9\u0BE7\x03\x02\x02\x02" + "\u0BEA\u0C00\x03\x02\x02\x02\u0BEB\u0BEC\f\b\x02\x02\u0BEC\u0BED\t\"\x02" + "\x02\u0BED\u0BFF\x05\u0112\x8A\t\u0BEE\u0BEF\f\x07\x02\x02\u0BEF\u0BF0" + "\t#\x02\x02\u0BF0\u0BFF\x05\u0112\x8A\b\u0BF1\u0BF2\f\x06\x02\x02\u0BF2" + "\u0BF3\x07\u0169\x02\x02\u0BF3\u0BFF\x05\u0112\x8A\x07\u0BF4\u0BF5\f\x05" + "\x02\x02\u0BF5\u0BF6\x07\u016C\x02\x02\u0BF6\u0BFF\x05\u0112\x8A\x06\u0BF7" + "\u0BF8\f\x04\x02\x02\u0BF8\u0BF9\x07\u016A\x02\x02\u0BF9\u0BFF\x05\u0112" + "\x8A\x05\u0BFA\u0BFB\f\x03\x02\x02\u0BFB\u0BFC\x05\u011C\x8F\x02\u0BFC" + "\u0BFD\x05\u0112\x8A\x04\u0BFD"; private static readonly _serializedATNSegment6: string = "\u0BFF\x03\x02\x02\x02\u0BFE\u0BEB\x03\x02\x02\x02\u0BFE\u0BEE\x03\x02" + "\x02\x02\u0BFE\u0BF1\x03\x02\x02\x02\u0BFE\u0BF4\x03\x02\x02\x02\u0BFE" + "\u0BF7\x03\x02\x02\x02\u0BFE\u0BFA\x03\x02\x02\x02\u0BFF\u0C02\x03\x02" + "\x02\x02\u0C00\u0BFE\x03\x02\x02\x02\u0C00\u0C01\x03\x02\x02\x02\u0C01" + "\u0113\x03\x02\x02\x02\u0C02\u0C00\x03\x02\x02\x02\u0C03\u0C04\t$\x02" + "\x02\u0C04\u0115\x03\x02\x02\x02\u0C05\u0C06\b\x8C\x01\x02\u0C06\u0CFF" + "\t%\x02\x02\u0C07\u0C08\t&\x02\x02\u0C08\u0C0B\x07\x04\x02\x02\u0C09\u0C0C" + "\x05\u0114\x8B\x02\u0C0A\u0C0C\x05\u0178\xBD\x02\u0C0B\u0C09\x03\x02\x02" + "\x02\u0C0B\u0C0A\x03\x02\x02\x02\u0C0C\u0C0D\x03\x02\x02\x02\u0C0D\u0C0E" + "\x07\x06\x02\x02\u0C0E\u0C0F\x05\u0112\x8A\x02\u0C0F\u0C10\x07\x06\x02" + "\x02\u0C10\u0C11\x05\u0112\x8A\x02\u0C11\u0C12\x07\x05\x02\x02\u0C12\u0CFF" + "\x03\x02\x02\x02\u0C13\u0C14\t\'\x02\x02\u0C14\u0C17\x07\x04\x02\x02\u0C15" + "\u0C18\x05\u0114\x8B\x02\u0C16\u0C18\x05\u0178\xBD\x02\u0C17\u0C15\x03" + "\x02\x02\x02\u0C17\u0C16\x03\x02\x02\x02\u0C18\u0C19\x03\x02\x02\x02\u0C19" + "\u0C1A\x07\x06\x02\x02\u0C1A\u0C1B\x05\u0112\x8A\x02\u0C1B\u0C1C\x07\x06" + "\x02\x02\u0C1C\u0C1D\x05\u0112\x8A\x02\u0C1D\u0C1E\x07\x05\x02\x02\u0C1E" + "\u0CFF\x03\x02\x02\x02\u0C1F\u0C21\x07%\x02\x02\u0C20\u0C22\x05\u0154" + "\xAB\x02\u0C21\u0C20\x03\x02\x02\x02\u0C22\u0C23\x03\x02\x02\x02\u0C23" + "\u0C21\x03\x02\x02\x02\u0C23\u0C24\x03\x02\x02\x02\u0C24\u0C27\x03\x02" + "\x02\x02\u0C25\u0C26\x07b\x02\x02\u0C26\u0C28\x05\u0106\x84\x02\u0C27" + "\u0C25\x03\x02\x02\x02\u0C27\u0C28\x03\x02\x02\x02\u0C28\u0C29\x03\x02" + "\x02\x02\u0C29\u0C2A\x07c\x02\x02\u0C2A\u0CFF\x03\x02\x02\x02\u0C2B\u0C2C" + "\x07%\x02\x02\u0C2C\u0C2E\x05\u0106\x84\x02\u0C2D\u0C2F\x05\u0154\xAB" + "\x02\u0C2E\u0C2D\x03\x02\x02\x02\u0C2F\u0C30\x03\x02\x02\x02\u0C30\u0C2E" + "\x03\x02\x02\x02\u0C30\u0C31\x03\x02\x02\x02\u0C31\u0C34\x03\x02\x02\x02" + "\u0C32\u0C33\x07b\x02\x02\u0C33\u0C35\x05\u0106\x84\x02\u0C34\u0C32\x03" + "\x02\x02\x02\u0C34\u0C35\x03\x02\x02\x02\u0C35\u0C36\x03\x02\x02\x02\u0C36" + "\u0C37\x07c\x02\x02\u0C37\u0CFF\x03\x02\x02\x02\u0C38\u0C39\t(\x02\x02" + "\u0C39\u0C3A\x07\x04\x02\x02\u0C3A\u0C3B\x05\u0106\x84\x02\u0C3B\u0C3C" + "\x07\x16\x02\x02\u0C3C\u0C3D\x05\u0138\x9D\x02\u0C3D\u0C3E\x07\x05\x02" + "\x02\u0C3E\u0CFF\x03\x02\x02\x02\u0C3F\u0C40\x07\u0119\x02\x02\u0C40\u0C49" + "\x07\x04\x02\x02\u0C41\u0C46\x05\xFA~\x02\u0C42\u0C43\x07\x06\x02\x02" + "\u0C43\u0C45\x05\xFA~\x02\u0C44\u0C42\x03\x02\x02\x02\u0C45\u0C48\x03" + "\x02\x02\x02\u0C46\u0C44\x03\x02\x02\x02\u0C46\u0C47\x03\x02\x02\x02\u0C47" + "\u0C4A\x03\x02\x02\x02\u0C48\u0C46\x03\x02\x02\x02\u0C49\u0C41\x03\x02" + "\x02\x02\u0C49\u0C4A\x03\x02\x02\x02\u0C4A\u0C4B\x03\x02\x02\x02\u0C4B" + "\u0CFF\x07\x05\x02\x02\u0C4C\u0C4D\x07t\x02\x02\u0C4D\u0C4E\x07\x04\x02" + "\x02\u0C4E\u0C51\x05\u0106\x84\x02\u0C4F\u0C50\x07\x8A\x02\x02\u0C50\u0C52" + "\x07\xC4\x02\x02\u0C51\u0C4F\x03\x02\x02\x02\u0C51\u0C52\x03\x02\x02\x02" + "\u0C52\u0C53\x03\x02\x02\x02\u0C53\u0C54\x07\x05\x02\x02\u0C54\u0CFF\x03" + "\x02\x02\x02\u0C55\u0C56\x07\x13\x02\x02\u0C56\u0C57\x07\x04\x02\x02\u0C57" + "\u0C5A\x05\u0106\x84\x02\u0C58\u0C59\x07\x8A\x02\x02\u0C59\u0C5B\x07\xC4" + "\x02\x02\u0C5A\u0C58\x03\x02\x02\x02\u0C5A\u0C5B\x03\x02\x02\x02\u0C5B" + "\u0C5C\x03\x02\x02\x02\u0C5C\u0C5D\x07\x05\x02\x02\u0C5D\u0CFF\x03\x02" + "\x02\x02\u0C5E\u0C5F\x07\x9D\x02\x02\u0C5F\u0C60\x07\x04\x02\x02\u0C60" + "\u0C63\x05\u0106\x84\x02\u0C61\u0C62\x07\x8A\x02\x02\u0C62\u0C64\x07\xC4" + "\x02\x02\u0C63\u0C61\x03\x02\x02\x02\u0C63\u0C64\x03\x02\x02\x02\u0C64" + "\u0C65\x03\x02\x02\x02\u0C65\u0C66\x07\x05\x02\x02\u0C66\u0CFF\x03\x02" + "\x02\x02\u0C67\u0C68\x07\xDD\x02\x02\u0C68\u0C69\x07\x04\x02\x02\u0C69" + "\u0C6A\x05\u0112\x8A\x02\u0C6A\u0C6B\x07\x8C\x02\x02\u0C6B\u0C6C\x05\u0112" + "\x8A\x02\u0C6C\u0C6D\x07\x05\x02\x02\u0C6D\u0CFF\x03\x02\x02\x02\u0C6E" + "\u0CFF\x05\u011A\x8E\x02\u0C6F\u0CFF\x07\u0165\x02\x02\u0C70\u0C71\x05" + "\u0166\xB4\x02\u0C71\u0C72\x07\x07\x02\x02\u0C72\u0C73\x07\u0165\x02\x02" + "\u0C73\u0CFF\x03\x02\x02\x02\u0C74\u0C75\x07\x04\x02\x02\u0C75\u0C78\x05" + "\xFA~\x02\u0C76\u0C77\x07\x06\x02\x02\u0C77\u0C79\x05\xFA~\x02\u0C78\u0C76" + "\x03\x02\x02\x02\u0C79\u0C7A\x03\x02\x02\x02\u0C7A\u0C78\x03\x02\x02\x02" + "\u0C7A\u0C7B\x03\x02\x02\x02\u0C7B\u0C7C\x03\x02\x02\x02\u0C7C\u0C7D\x07" + "\x05\x02\x02\u0C7D\u0CFF\x03\x02\x02\x02\u0C7E\u0C7F\x07\x04\x02\x02\u0C7F" + "\u0C80\x05\x1C\x0F\x02\u0C80\u0C81\x07\x05\x02\x02\u0C81\u0CFF\x03\x02" + "\x02\x02\u0C82\u0C83\x07\x88\x02\x02\u0C83\u0C84\x07\x04\x02\x02\u0C84" + "\u0C85\x05\u0106\x84\x02\u0C85\u0C86\x07\x05\x02\x02\u0C86\u0CFF\x03\x02" + "\x02\x02\u0C87\u0C88\x05\u0162\xB2\x02\u0C88\u0C94\x07\x04\x02\x02\u0C89" + "\u0C8B\x05\xBE`\x02\u0C8A\u0C89\x03\x02\x02\x02\u0C8A\u0C8B\x03\x02\x02" + "\x02\u0C8B\u0C8C\x03\x02\x02\x02\u0C8C\u0C91\x05\u010A\x86\x02\u0C8D\u0C8E" + "\x07\x06\x02\x02\u0C8E\u0C90\x05\u010A\x86\x02\u0C8F\u0C8D\x03\x02\x02" + "\x02\u0C90\u0C93\x03\x02\x02\x02\u0C91\u0C8F\x03\x02\x02\x02\u0C91\u0C92" + "\x03\x02\x02\x02\u0C92\u0C95\x03\x02\x02\x02\u0C93\u0C91\x03\x02\x02\x02" + "\u0C94\u0C8A\x03\x02\x02\x02\u0C94\u0C95\x03\x02\x02\x02\u0C95\u0C96\x03" + "\x02\x02\x02\u0C96\u0C9D\x07\x05\x02\x02\u0C97\u0C98\x07r\x02\x02\u0C98" + "\u0C99\x07\x04\x02\x02\u0C99\u0C9A\x07\u0153\x02\x02\u0C9A\u0C9B\x05\u010E" + "\x88\x02\u0C9B\u0C9C\x07\x05\x02\x02\u0C9C\u0C9E\x03\x02\x02\x02\u0C9D" + "\u0C97\x03\x02\x02\x02\u0C9D\u0C9E\x03\x02\x02\x02\u0C9E\u0CA1\x03\x02" + "\x02\x02\u0C9F\u0CA0\t)\x02\x02\u0CA0\u0CA2\x07\xC4\x02\x02\u0CA1\u0C9F" + "\x03\x02\x02\x02\u0CA1\u0CA2\x03\x02\x02\x02\u0CA2\u0CA5\x03\x02\x02\x02" + "\u0CA3\u0CA4\x07\xD1\x02\x02\u0CA4\u0CA6\x05\u015A\xAE\x02\u0CA5\u0CA3" + "\x03\x02\x02\x02\u0CA5\u0CA6\x03\x02\x02\x02\u0CA6\u0CFF\x03\x02\x02\x02" + "\u0CA7\u0CA8\x05\u016C\xB7\x02\u0CA8\u0CA9\x07\u016E\x02\x02\u0CA9\u0CAA" + "\x05\u0106\x84\x02\u0CAA\u0CFF\x03\x02\x02\x02\u0CAB\u0CAC\x07\x04\x02" + "\x02\u0CAC\u0CAF\x05\u016C\xB7\x02\u0CAD\u0CAE\x07\x06\x02\x02\u0CAE\u0CB0" + "\x05\u016C\xB7\x02\u0CAF\u0CAD\x03\x02\x02\x02\u0CB0\u0CB1\x03\x02\x02" + "\x02\u0CB1\u0CAF\x03\x02\x02\x02\u0CB1\u0CB2\x03\x02\x02\x02\u0CB2\u0CB3" + "\x03\x02\x02\x02\u0CB3\u0CB4\x07\x05\x02\x02\u0CB4\u0CB5\x07\u016E\x02" + "\x02\u0CB5\u0CB6\x05\u0106\x84\x02\u0CB6\u0CFF\x03\x02\x02\x02\u0CB7\u0CFF" + "\x05\u016C\xB7\x02\u0CB8\u0CB9\x07\x04\x02\x02\u0CB9\u0CBA\x05\u0106\x84" + "\x02\u0CBA\u0CBB\x07\x05\x02\x02\u0CBB\u0CFF\x03\x02\x02\x02\u0CBC\u0CBD" + "\x07n\x02\x02\u0CBD\u0CBE\x07\x04\x02\x02\u0CBE\u0CBF\x05\u016C\xB7\x02" + "\u0CBF\u0CC0\x07{\x02\x02\u0CC0\u0CC1\x05\u0112\x8A\x02\u0CC1\u0CC2\x07" + "\x05\x02\x02\u0CC2\u0CFF\x03\x02\x02\x02\u0CC3\u0CC4\t*\x02\x02\u0CC4" + "\u0CC5\x07\x04\x02\x02\u0CC5\u0CC6\x05\u0112\x8A\x02\u0CC6\u0CC7\t+\x02" + "\x02\u0CC7\u0CCA\x05\u0112\x8A\x02\u0CC8\u0CC9\t,\x02\x02\u0CC9\u0CCB" + "\x05\u0112\x8A\x02\u0CCA\u0CC8\x03\x02\x02\x02\u0CCA\u0CCB\x03\x02\x02" + "\x02\u0CCB\u0CCC\x03\x02\x02\x02\u0CCC\u0CCD\x07\x05\x02\x02\u0CCD\u0CFF" + "\x03\x02\x02\x02\u0CCE\u0CCF\x07\u0136\x02\x02\u0CCF\u0CD1\x07\x04\x02" + "\x02\u0CD0\u0CD2\t-\x02\x02\u0CD1\u0CD0\x03\x02\x02\x02\u0CD1\u0CD2\x03" + "\x02\x02\x02\u0CD2\u0CD4\x03\x02\x02\x02\u0CD3\u0CD5\x05\u0112\x8A\x02" + "\u0CD4\u0CD3\x03\x02\x02\x02\u0CD4\u0CD5\x03\x02\x02\x02\u0CD5\u0CD6\x03" + "\x02\x02\x02\u0CD6\u0CD7\x07{\x02\x02\u0CD7\u0CD8\x05\u0112\x8A\x02\u0CD8" + "\u0CD9\x07\x05\x02\x02\u0CD9\u0CFF\x03\x02\x02\x02\u0CDA\u0CDB\x07\xD3" + "\x02\x02\u0CDB\u0CDC\x07\x04\x02\x02\u0CDC\u0CDD\x05\u0112\x8A\x02\u0CDD" + "\u0CDE\x07\xDC\x02\x02\u0CDE\u0CDF\x05\u0112\x8A\x02\u0CDF\u0CE0\x07{" + "\x02\x02\u0CE0\u0CE3\x05\u0112\x8A\x02\u0CE1\u0CE2\x07w\x02\x02\u0CE2" + "\u0CE4\x05\u0112\x8A\x02\u0CE3\u0CE1\x03\x02\x02\x02\u0CE3\u0CE4\x03\x02" + "\x02\x02\u0CE4\u0CE5\x03\x02\x02\x02\u0CE5\u0CE6\x07\x05\x02\x02\u0CE6" + "\u0CFF\x03\x02\x02\x02\u0CE7\u0CE8\t.\x02\x02\u0CE8\u0CE9\x07\x04\x02" + "\x02\u0CE9\u0CEA\x05\u0112\x8A\x02\u0CEA\u0CEB\x07\x05\x02\x02\u0CEB\u0CEC" + "\x07\u0156\x02\x02\u0CEC\u0CED\x07\x82\x02\x02\u0CED\u0CEE\x07\x04\x02" + "\x02\u0CEE\u0CEF\x07\xCD\x02\x02\u0CEF\u0CF0\x07!\x02\x02\u0CF0\u0CF1" + "\x05f4\x02\u0CF1\u0CF8\x07\x05\x02\x02\u0CF2\u0CF3\x07r\x02\x02\u0CF3" + "\u0CF4\x07\x04\x02\x02\u0CF4\u0CF5\x07\u0153\x02\x02\u0CF5\u0CF6\x05\u010E" + "\x88\x02\u0CF6\u0CF7\x07\x05\x02\x02\u0CF7\u0CF9\x03\x02\x02\x02\u0CF8" + "\u0CF2\x03\x02\x02\x02\u0CF8\u0CF9\x03\x02\x02\x02\u0CF9\u0CFC\x03\x02" + "\x02\x02\u0CFA\u0CFB\x07\xD1\x02\x02\u0CFB\u0CFD\x05\u015A\xAE\x02\u0CFC" + "\u0CFA\x03\x02\x02\x02\u0CFC\u0CFD\x03\x02\x02\x02\u0CFD\u0CFF\x03\x02" + "\x02\x02\u0CFE\u0C05\x03\x02\x02\x02\u0CFE\u0C07\x03\x02\x02\x02\u0CFE" + "\u0C13\x03\x02\x02\x02\u0CFE\u0C1F\x03\x02\x02\x02\u0CFE\u0C2B\x03\x02" + "\x02\x02\u0CFE\u0C38\x03\x02\x02\x02\u0CFE\u0C3F\x03\x02\x02\x02\u0CFE" + "\u0C4C\x03\x02\x02\x02\u0CFE\u0C55\x03\x02\x02\x02\u0CFE\u0C5E\x03\x02" + "\x02\x02\u0CFE\u0C67\x03\x02\x02\x02\u0CFE\u0C6E\x03\x02\x02\x02\u0CFE" + "\u0C6F\x03\x02\x02\x02\u0CFE\u0C70\x03\x02\x02\x02\u0CFE\u0C74\x03\x02" + "\x02\x02\u0CFE\u0C7E\x03\x02\x02\x02\u0CFE\u0C82\x03\x02\x02\x02\u0CFE" + "\u0C87\x03\x02\x02\x02\u0CFE\u0CA7\x03\x02\x02\x02\u0CFE\u0CAB\x03\x02" + "\x02\x02\u0CFE\u0CB7\x03\x02\x02\x02\u0CFE\u0CB8\x03\x02\x02\x02\u0CFE" + "\u0CBC\x03\x02\x02\x02\u0CFE\u0CC3\x03\x02\x02\x02\u0CFE\u0CCE\x03\x02" + "\x02\x02\u0CFE\u0CDA\x03\x02\x02\x02\u0CFE\u0CE7\x03\x02\x02\x02\u0CFF" + "\u0D0A\x03\x02\x02\x02\u0D00\u0D01\f\v\x02\x02\u0D01\u0D02\x07\b\x02\x02" + "\u0D02\u0D03\x05\u0112\x8A\x02\u0D03\u0D04\x07\t\x02\x02\u0D04\u0D09\x03" + "\x02\x02\x02\u0D05\u0D06\f\t\x02\x02\u0D06\u0D07\x07\x07\x02\x02\u0D07" + "\u0D09\x05\u016C\xB7\x02\u0D08\u0D00\x03\x02\x02\x02\u0D08\u0D05\x03\x02" + "\x02\x02\u0D09\u0D0C\x03\x02\x02\x02\u0D0A\u0D08\x03\x02\x02\x02\u0D0A" + "\u0D0B\x03\x02\x02\x02\u0D0B\u0117\x03\x02\x02\x02\u0D0C\u0D0A\x03\x02" + "\x02\x02\u0D0D\u0D15\x07I\x02\x02\u0D0E\u0D15\x07\u012A\x02\x02\u0D0F" + "\u0D15\x07\u012B\x02\x02\u0D10\u0D15\x07\u012C\x02\x02\u0D11\u0D15\x07" + "\x95\x02\x02\u0D12\u0D15\x07\x85\x02\x02\u0D13\u0D15\x05\u016C\xB7\x02" + "\u0D14\u0D0D\x03\x02\x02\x02\u0D14\u0D0E\x03\x02\x02\x02\u0D14\u0D0F\x03" + "\x02\x02\x02\u0D14\u0D10\x03\x02\x02\x02\u0D14\u0D11\x03\x02\x02\x02\u0D14" + "\u0D12\x03\x02\x02\x02\u0D14\u0D13\x03\x02\x02\x02\u0D15\u0119\x03\x02" + "\x02\x02\u0D16\u0D26\x07\xC3\x02\x02\u0D17\u0D26\x07\u0172\x02\x02\u0D18" + "\u0D19\x07\u016D\x02\x02\u0D19\u0D26\x05\u016C\xB7\x02\u0D1A\u0D26\x05" + "\u0124\x93\x02\u0D1B\u0D1C\x05\u0118\x8D\x02\u0D1C\u0D1D\x05\u0178\xBD" + "\x02\u0D1D\u0D26\x03\x02\x02\x02\u0D1E\u0D26\x05\u0174\xBB\x02\u0D1F\u0D26" + "\x05\u0122\x92\x02\u0D20\u0D22\x05\u0178\xBD\x02\u0D21\u0D20\x03\x02\x02" + "\x02\u0D22\u0D23\x03\x02\x02\x02\u0D23\u0D21\x03\x02\x02\x02\u0D23\u0D24" + "\x03\x02\x02\x02\u0D24\u0D26\x03\x02\x02\x02\u0D25\u0D16\x03\x02\x02\x02" + "\u0D25\u0D17\x03\x02\x02\x02\u0D25\u0D18\x03\x02\x02\x02\u0D25\u0D1A\x03" + "\x02\x02\x02\u0D25\u0D1B\x03\x02\x02\x02\u0D25\u0D1E\x03\x02\x02\x02\u0D25" + "\u0D1F\x03\x02\x02\x02\u0D25\u0D21\x03\x02\x02\x02\u0D26\u011B\x03\x02" + "\x02\x02\u0D27\u0D28\t/\x02\x02\u0D28\u011D\x03\x02\x02\x02\u0D29\u0D2A" + "\t0\x02\x02\u0D2A\u011F\x03\x02\x02\x02\u0D2B\u0D2C\t1\x02\x02\u0D2C\u0121" + "\x03\x02\x02\x02\u0D2D\u0D2E\t2\x02\x02\u0D2E\u0123\x03\x02\x02\x02\u0D2F" + "\u0D32\x07\x95\x02\x02\u0D30\u0D33\x05\u0126\x94\x02\u0D31\u0D33\x05\u012A" + "\x96\x02\u0D32\u0D30\x03\x02\x02\x02\u0D32\u0D31\x03\x02\x02\x02\u0D33" + "\u0125\x03\x02\x02\x02\u0D34\u0D36\x05\u0128\x95\x02\u0D35\u0D37\x05\u012C" + "\x97\x02\u0D36\u0D35\x03\x02\x02\x02\u0D36\u0D37\x03\x02\x02\x02\u0D37" + "\u0127\x03\x02\x02\x02\u0D38\u0D39\x05\u012E\x98\x02\u0D39\u0D3A\x05\u0130" + "\x99\x02\u0D3A\u0D3C\x03\x02\x02\x02\u0D3B\u0D38\x03\x02\x02\x02\u0D3C" + "\u0D3D\x03\x02\x02\x02\u0D3D\u0D3B\x03\x02\x02\x02\u0D3D\u0D3E\x03\x02" + "\x02\x02\u0D3E\u0129\x03\x02\x02\x02\u0D3F\u0D42\x05\u012C\x97\x02\u0D40" + "\u0D43\x05\u0128\x95\x02\u0D41\u0D43\x05\u012C\x97\x02\u0D42\u0D40\x03" + "\x02\x02\x02\u0D42\u0D41\x03\x02\x02\x02\u0D42\u0D43\x03\x02\x02\x02\u0D43" + "\u012B\x03\x02\x02\x02\u0D44\u0D45\x05\u012E\x98\x02\u0D45\u0D46\x05\u0132" + "\x9A\x02\u0D46\u0D47\x07\u0130\x02\x02\u0D47\u0D48\x05\u0132\x9A\x02\u0D48" + "\u012D\x03\x02\x02\x02\u0D49\u0D4B\t3\x02\x02\u0D4A\u0D49\x03\x02\x02" + "\x02\u0D4A\u0D4B\x03\x02\x02\x02\u0D4B\u0D4F\x03\x02\x02\x02\u0D4C\u0D50" + "\x07\u0178\x02\x02\u0D4D\u0D50\x07\u017A\x02\x02\u0D4E\u0D50\x05\u0178" + "\xBD\x02\u0D4F\u0D4C\x03\x02\x02\x02\u0D4F\u0D4D\x03\x02\x02\x02\u0D4F" + "\u0D4E\x03\x02\x02\x02\u0D50\u012F\x03\x02\x02\x02\u0D51\u0D52\t4\x02" + "\x02\u0D52\u0131\x03\x02\x02\x02\u0D53\u0D54\t5\x02\x02\u0D54\u0133\x03" + "\x02\x02\x02\u0D55\u0D59\x07t\x02\x02\u0D56\u0D57\x07\v\x02\x02\u0D57" + "\u0D59\x05\u0168\xB5\x02\u0D58\u0D55\x03\x02\x02\x02\u0D58\u0D56\x03\x02" + "\x02\x02\u0D59\u0135\x03\x02\x02\x02\u0D5A\u0D79\x07\x1D\x02\x02\u0D5B" + "\u0D79\x07\u012F\x02\x02\u0D5C\u0D79\x07\"\x02\x02\u0D5D\u0D79\x07\u010F" + "\x02\x02\u0D5E\u0D79\x07\u010B\x02\x02\u0D5F\u0D79\x07\x96\x02\x02\u0D60" + "\u0D79\x07\x97\x02\x02\u0D61\u0D79\x07\x1B\x02\x02\u0D62\u0D79\x07\xAD" + "\x02\x02\u0D63\u0D79\x07u\x02\x02\u0D64\u0D79\x07\xE6\x02\x02\u0D65\u0D79" + "\x07`\x02\x02\u0D66\u0D79\x07I\x02\x02\u0D67\u0D79\x07\u012A\x02\x02\u0D68" + "\u0D79\x07\u012C\x02\x02\u0D69\u0D79\x07\u012B\x02\x02\u0D6A\u0D79\x07" + "\u0118\x02\x02\u0D6B\u0D79\x07+\x02\x02\u0D6C\u0D79\x07*\x02\x02\u0D6D" + "\u0D79\x07\u0149\x02\x02\u0D6E\u0D79\x07\x1C\x02\x02\u0D6F\u0D79\x07R" + "\x02\x02\u0D70\u0D79\x07Q\x02\x02\u0D71\u0D79\x07\xC5\x02\x02\u0D72\u0D79" + "\x07\u014F\x02\x02\u0D73\u0D79\x07\x95\x02\x02\u0D74\u0D79\x07\x15\x02" + "\x02\u0D75\u0D79\x07\u0119\x02\x02\u0D76\u0D79\x07\xAF\x02\x02\u0D77\u0D79" + "\x05\u016C\xB7\x02\u0D78\u0D5A\x03\x02\x02\x02\u0D78\u0D5B\x03\x02\x02" + "\x02\u0D78\u0D5C\x03\x02\x02\x02\u0D78\u0D5D\x03\x02\x02\x02\u0D78\u0D5E" + "\x03\x02\x02\x02\u0D78\u0D5F\x03\x02\x02\x02\u0D78\u0D60\x03\x02\x02\x02" + "\u0D78\u0D61\x03\x02\x02\x02\u0D78\u0D62\x03\x02\x02\x02\u0D78\u0D63\x03" + "\x02\x02\x02\u0D78\u0D64\x03\x02\x02\x02\u0D78\u0D65\x03\x02\x02\x02\u0D78" + "\u0D66\x03\x02\x02\x02\u0D78\u0D67\x03\x02\x02\x02\u0D78\u0D68\x03\x02" + "\x02\x02\u0D78\u0D69\x03\x02\x02\x02\u0D78\u0D6A\x03\x02\x02\x02\u0D78" + "\u0D6B\x03\x02\x02\x02\u0D78\u0D6C\x03\x02\x02\x02\u0D78\u0D6D\x03\x02" + "\x02\x02\u0D78\u0D6E\x03\x02\x02\x02\u0D78\u0D6F\x03\x02\x02\x02\u0D78" + "\u0D70\x03\x02\x02\x02\u0D78\u0D71\x03\x02\x02\x02\u0D78\u0D72\x03\x02" + "\x02\x02\u0D78\u0D73\x03\x02\x02\x02\u0D78\u0D74\x03\x02\x02\x02\u0D78" + "\u0D75\x03\x02\x02\x02\u0D78\u0D76\x03\x02\x02\x02\u0D78\u0D77\x03\x02" + "\x02\x02\u0D79\u0137\x03\x02\x02\x02\u0D7A\u0D7B\x07\x15\x02\x02\u0D7B" + "\u0D7C\x07\u015E\x02\x02\u0D7C\u0D7D\x05\u0138\x9D\x02\u0D7D\u0D7E\x07" + "\u0160\x02\x02\u0D7E\u0DA9\x03\x02\x02\x02\u0D7F\u0D80\x07\xAF\x02\x02" + "\u0D80\u0D81\x07\u015E\x02\x02\u0D81\u0D82\x05\u0138\x9D\x02\u0D82\u0D83" + "\x07\x06\x02\x02\u0D83\u0D84\x05\u0138\x9D\x02\u0D84\u0D85\x07\u0160\x02" + "\x02\u0D85\u0DA9\x03\x02\x02\x02\u0D86\u0D8D\x07\u0119\x02\x02\u0D87\u0D89" + "\x07\u015E\x02\x02\u0D88\u0D8A\x05\u0150\xA9\x02\u0D89\u0D88\x03\x02\x02" + "\x02\u0D89\u0D8A\x03\x02\x02\x02\u0D8A\u0D8B\x03\x02\x02\x02\u0D8B\u0D8E" + "\x07\u0160\x02\x02\u0D8C\u0D8E\x07\u015C\x02\x02\u0D8D\u0D87\x03\x02\x02" + "\x02\u0D8D\u0D8C\x03\x02\x02\x02\u0D8E\u0DA9\x03\x02\x02\x02\u0D8F\u0D90" + "\x07\x95\x02\x02\u0D90\u0D93\t6\x02\x02\u0D91\u0D92\x07\u0130\x02\x02" + "\u0D92\u0D94\x07\xB8\x02\x02\u0D93\u0D91\x03\x02\x02\x02\u0D93\u0D94\x03" + "\x02\x02\x02\u0D94\u0DA9\x03\x02\x02\x02\u0D95\u0D96\x07\x95\x02\x02\u0D96" + "\u0D99\t7\x02\x02\u0D97\u0D98\x07\u0130\x02\x02\u0D98\u0D9A\t8\x02\x02" + "\u0D99\u0D97\x03\x02\x02\x02\u0D99\u0D9A\x03\x02\x02\x02\u0D9A\u0DA9\x03" + "\x02\x02\x02\u0D9B\u0DA6\x05\u0136\x9C\x02\u0D9C\u0D9D\x07\x04\x02\x02" + "\u0D9D\u0DA2\x07\u0178\x02\x02\u0D9E\u0D9F\x07\x06\x02\x02\u0D9F\u0DA1" + "\x07\u0178\x02\x02\u0DA0\u0D9E\x03\x02\x02\x02\u0DA1\u0DA4\x03\x02\x02" + "\x02\u0DA2\u0DA0\x03\x02\x02\x02\u0DA2\u0DA3\x03\x02\x02\x02\u0DA3\u0DA5" + "\x03\x02\x02\x02\u0DA4\u0DA2\x03\x02\x02\x02\u0DA5\u0DA7\x07\x05\x02\x02" + "\u0DA6\u0D9C\x03\x02\x02\x02\u0DA6\u0DA7\x03\x02\x02\x02\u0DA7\u0DA9\x03" + "\x02\x02\x02\u0DA8\u0D7A\x03\x02\x02\x02\u0DA8\u0D7F\x03\x02\x02\x02\u0DA8" + "\u0D86\x03\x02\x02\x02\u0DA8\u0D8F\x03\x02\x02\x02\u0DA8\u0D95\x03\x02" + "\x02\x02\u0DA8\u0D9B\x03\x02\x02\x02\u0DA9\u0139\x03\x02\x02\x02\u0DAA" + "\u0DAF\x05\u013C\x9F\x02\u0DAB\u0DAC\x07\x06\x02\x02\u0DAC\u0DAE\x05\u013C" + "\x9F\x02\u0DAD\u0DAB\x03\x02\x02\x02\u0DAE\u0DB1\x03\x02\x02\x02\u0DAF" + "\u0DAD\x03\x02\x02\x02\u0DAF\u0DB0\x03\x02\x02\x02\u0DB0\u013B\x03\x02" + "\x02\x02\u0DB1\u0DAF\x03\x02\x02\x02\u0DB2\u0DB3\x05\xF0y\x02\u0DB3\u0DB7" + "\x05\u0138\x9D\x02\u0DB4\u0DB6\x05\u013E\xA0\x02\u0DB5\u0DB4\x03\x02\x02" + "\x02\u0DB6\u0DB9\x03\x02\x02\x02\u0DB7\u0DB5\x03\x02\x02\x02\u0DB7\u0DB8" + "\x03\x02\x02\x02\u0DB8\u013D\x03\x02\x02\x02\u0DB9\u0DB7\x03\x02\x02\x02" + "\u0DBA\u0DBB\x07\xC2\x02\x02\u0DBB\u0DC0\x07\xC3\x02\x02\u0DBC\u0DC0\x05" + "\u0140\xA1\x02\u0DBD\u0DC0\x05\x1A\x0E\x02\u0DBE\u0DC0\x05\u0134\x9B\x02" + "\u0DBF\u0DBA\x03\x02\x02\x02\u0DBF\u0DBC\x03\x02\x02\x02\u0DBF\u0DBD\x03" + "\x02\x02\x02\u0DBF\u0DBE\x03\x02\x02\x02\u0DC0\u013F\x03\x02\x02\x02\u0DC1" + "\u0DC2\x07T\x02\x02\u0DC2\u0DC3\x05\u0106\x84\x02\u0DC3\u0141\x03\x02" + "\x02\x02\u0DC4\u0DC5\t9\x02\x02\u0DC5\u0DC6\x05\u0106\x84\x02\u0DC6\u0143" + "\x03\x02\x02\x02\u0DC7\u0DCC\x05\u0146\xA4\x02\u0DC8\u0DC9\x07\x06\x02" + "\x02\u0DC9\u0DCB\x05\u0146\xA4\x02\u0DCA\u0DC8\x03\x02\x02\x02\u0DCB\u0DCE" + "\x03\x02\x02\x02\u0DCC\u0DCA\x03\x02\x02\x02\u0DCC\u0DCD\x03\x02\x02\x02" + "\u0DCD\u0145\x03\x02\x02\x02\u0DCE\u0DCC\x03\x02\x02\x02\u0DCF\u0DD0\x05" + "\u0168\xB5\x02\u0DD0\u0DD3\x05\u0138\x9D\x02\u0DD1\u0DD2\x07\xC2\x02\x02" + "\u0DD2\u0DD4\x07\xC3\x02\x02\u0DD3\u0DD1\x03\x02\x02\x02\u0DD3\u0DD4\x03" + "\x02\x02\x02\u0DD4\u0DD6\x03\x02\x02\x02\u0DD5\u0DD7\x05\x1A\x0E\x02\u0DD6" + "\u0DD5\x03\x02\x02\x02\u0DD6\u0DD7\x03\x02\x02\x02\u0DD7\u0147\x03\x02" + "\x02\x02\u0DD8\u0DDD\x05\u014A\xA6\x02\u0DD9\u0DDA\x07\x06\x02\x02\u0DDA" + "\u0DDC\x05\u014A\xA6\x02\u0DDB\u0DD9\x03\x02\x02\x02\u0DDC\u0DDF\x03\x02" + "\x02\x02\u0DDD\u0DDB\x03\x02\x02\x02\u0DDD\u0DDE\x03\x02\x02\x02\u0DDE" + "\u0149\x03\x02\x02\x02\u0DDF\u0DDD\x03\x02\x02\x02\u0DE0\u0DE1\x05\u0168" + "\xB5\x02\u0DE1\u0DE5\x05\u0138\x9D\x02\u0DE2\u0DE4\x05\u014C\xA7\x02\u0DE3" + "\u0DE2\x03\x02\x02\x02\u0DE4\u0DE7\x03\x02\x02\x02\u0DE5\u0DE3\x03\x02" + "\x02\x02\u0DE5\u0DE6\x03\x02\x02\x02\u0DE6\u014B\x03\x02\x02\x02\u0DE7" + "\u0DE5\x03\x02\x02\x02\u0DE8\u0DE9\x07\xC2\x02\x02\u0DE9\u0DEE\x07\xC3" + "\x02\x02\u0DEA\u0DEE\x05\u0140\xA1\x02\u0DEB\u0DEE\x05\u014E\xA8\x02\u0DEC" + "\u0DEE\x05\x1A\x0E\x02\u0DED\u0DE8\x03\x02\x02\x02\u0DED\u0DEA\x03\x02" + "\x02\x02\u0DED\u0DEB\x03\x02\x02\x02\u0DED\u0DEC\x03\x02\x02\x02\u0DEE" + "\u014D\x03\x02\x02\x02\u0DEF\u0DF0\x07\x7F\x02\x02\u0DF0\u0DF1\x07\x0E" + "\x02\x02\u0DF1\u0DF2\x07\x16\x02\x02\u0DF2\u0DF3\x07\x04\x02\x02\u0DF3" + "\u0DF4\x05\u0106\x84\x02\u0DF4\u0DF5\x07\x05\x02\x02\u0DF5\u014F\x03\x02" + "\x02\x02\u0DF6\u0DFB\x05\u0152\xAA\x02\u0DF7\u0DF8\x07\x06\x02\x02\u0DF8" + "\u0DFA\x05\u0152\xAA\x02\u0DF9\u0DF7\x03\x02\x02\x02\u0DFA\u0DFD\x03\x02" + "\x02\x02\u0DFB\u0DF9\x03\x02\x02\x02\u0DFB\u0DFC\x03\x02\x02\x02\u0DFC" + "\u0151\x03\x02\x02\x02\u0DFD\u0DFB\x03\x02\x02\x02\u0DFE\u0E00\x05\u016C" + "\xB7\x02\u0DFF\u0E01\x07\u016D\x02\x02\u0E00\u0DFF\x03\x02\x02\x02\u0E00" + "\u0E01\x03\x02\x02\x02\u0E01\u0E02\x03\x02\x02\x02\u0E02\u0E05\x05\u0138" + "\x9D\x02\u0E03\u0E04\x07\xC2\x02\x02\u0E04\u0E06\x07\xC3\x02\x02\u0E05" + "\u0E03\x03\x02\x02\x02\u0E05\u0E06\x03\x02\x02\x02\u0E06\u0E08\x03\x02" + "\x02\x02\u0E07\u0E09\x05\x1A\x0E\x02\u0E08\u0E07\x03\x02\x02\x02\u0E08" + "\u0E09\x03\x02\x02\x02\u0E09\u0153\x03\x02\x02\x02\u0E0A\u0E0B\x07\u0152" + "\x02\x02\u0E0B\u0E0C\x05\u0106\x84\x02\u0E0C\u0E0D\x07\u0127\x02\x02\u0E0D" + "\u0E0E\x05\u0106\x84\x02\u0E0E\u0155\x03\x02\x02\x02\u0E0F\u0E10\x07\u0154" + "\x02\x02\u0E10\u0E15\x05\u0158\xAD\x02\u0E11\u0E12\x07\x06\x02\x02\u0E12" + "\u0E14\x05\u0158\xAD\x02\u0E13\u0E11\x03\x02\x02\x02\u0E14\u0E17\x03\x02" + "\x02\x02\u0E15\u0E13\x03\x02\x02\x02\u0E15\u0E16\x03\x02\x02\x02\u0E16" + "\u0157\x03\x02\x02\x02\u0E17\u0E15\x03\x02\x02\x02\u0E18\u0E19\x05\u0168" + "\xB5\x02\u0E19\u0E1A\x07\x16\x02\x02\u0E1A\u0E1B\x05\u015A\xAE\x02\u0E1B" + "\u0159\x03\x02\x02\x02\u0E1C\u0E4B\x05\u0168\xB5\x02\u0E1D\u0E1E\x07\x04" + "\x02\x02\u0E1E\u0E1F\x05\u0168\xB5\x02\u0E1F\u0E20\x07\x05\x02\x02\u0E20" + "\u0E4B\x03\x02\x02\x02\u0E21\u0E44\x07\x04\x02\x02\u0E22\u0E23\x07.\x02" + "\x02\u0E23\u0E24\x07!\x02\x02\u0E24\u0E29\x05\u0106\x84\x02\u0E25\u0E26" + "\x07\x06\x02\x02\u0E26\u0E28\x05\u0106\x84\x02\u0E27\u0E25\x03\x02\x02" + "\x02\u0E28\u0E2B\x03\x02\x02\x02\u0E29\u0E27\x03\x02\x02\x02\u0E29\u0E2A" + "\x03\x02\x02\x02\u0E2A\u0E45\x03\x02\x02\x02\u0E2B\u0E29\x03\x02\x02\x02" + "\u0E2C\u0E2D\t\x1A\x02\x02\u0E2D\u0E2E\x07!\x02\x02\u0E2E\u0E33\x05\u0106" + "\x84\x02\u0E2F\u0E30\x07\x06\x02\x02\u0E30\u0E32\x05\u0106\x84\x02\u0E31" + "\u0E2F\x03\x02\x02\x02\u0E32\u0E35\x03\x02\x02\x02\u0E33\u0E31\x03\x02" + "\x02\x02\u0E33\u0E34\x03\x02\x02\x02\u0E34\u0E37\x03\x02\x02\x02\u0E35" + "\u0E33\x03\x02\x02\x02\u0E36\u0E2C\x03\x02\x02\x02\u0E36\u0E37\x03\x02" + "\x02\x02\u0E37\u0E42\x03\x02\x02\x02\u0E38\u0E39\t\x1B\x02\x02\u0E39\u0E3A" + "\x07!\x02\x02\u0E3A\u0E3F\x05f4\x02\u0E3B\u0E3C\x07\x06\x02\x02\u0E3C" + "\u0E3E\x05f4\x02\u0E3D\u0E3B\x03\x02\x02\x02\u0E3E\u0E41\x03\x02\x02\x02" + "\u0E3F\u0E3D\x03\x02\x02\x02\u0E3F\u0E40\x03\x02\x02\x02\u0E40\u0E43\x03" + "\x02\x02\x02\u0E41\u0E3F\x03\x02\x02\x02\u0E42\u0E38\x03\x02\x02\x02\u0E42" + "\u0E43\x03\x02\x02\x02\u0E43\u0E45\x03\x02\x02\x02\u0E44\u0E22\x03\x02" + "\x02\x02\u0E44\u0E36\x03\x02\x02\x02\u0E45\u0E47\x03\x02\x02\x02\u0E46" + "\u0E48\x05\u015C\xAF\x02\u0E47\u0E46\x03\x02\x02\x02\u0E47\u0E48\x03\x02" + "\x02\x02\u0E48\u0E49\x03\x02\x02\x02\u0E49\u0E4B\x07\x05\x02\x02\u0E4A" + "\u0E1C\x03\x02\x02\x02\u0E4A\u0E1D\x03\x02\x02\x02\u0E4A\u0E21\x03\x02" + "\x02\x02\u0E4B\u015B\x03\x02\x02\x02\u0E4C\u0E4D\x07\xE5\x02\x02\u0E4D" + "\u0E5D\x05\u015E\xB0\x02\u0E4E\u0E4F\x07\xFD\x02\x02\u0E4F\u0E5D\x05\u015E" + "\xB0\x02\u0E50\u0E51\x07\xE5\x02\x02\u0E51\u0E52\x07\x1A\x02\x02\u0E52" + "\u0E53\x05\u015E\xB0\x02\u0E53\u0E54\x07\x10\x02\x02\u0E54\u0E55\x05\u015E" + "\xB0\x02\u0E55\u0E5D\x03\x02\x02\x02\u0E56\u0E57\x07\xFD\x02\x02\u0E57" + "\u0E58\x07\x1A\x02\x02\u0E58\u0E59\x05\u015E\xB0\x02\u0E59\u0E5A\x07\x10" + "\x02\x02\u0E5A\u0E5B\x05\u015E\xB0\x02\u0E5B\u0E5D\x03\x02\x02\x02\u0E5C" + "\u0E4C\x03\x02\x02\x02\u0E5C\u0E4E\x03\x02\x02\x02\u0E5C\u0E50\x03\x02" + "\x02\x02\u0E5C\u0E56\x03\x02\x02\x02\u0E5D\u015D\x03\x02\x02\x02\u0E5E" + "\u0E5F\x07\u013C\x02\x02\u0E5F\u0E66\t:\x02\x02\u0E60\u0E61\x07@\x02\x02" + "\u0E61\u0E66\x07\xFC\x02\x02\u0E62\u0E63\x05\u0106\x84\x02\u0E63\u0E64" + "\t:\x02\x02\u0E64\u0E66\x03\x02\x02\x02\u0E65\u0E5E\x03\x02\x02\x02\u0E65" + "\u0E60\x03\x02\x02\x02\u0E65\u0E62\x03\x02\x02\x02\u0E66\u015F\x03\x02" + "\x02\x02\u0E67\u0E6C\x05\u0166\xB4\x02\u0E68\u0E69\x07\x06\x02\x02\u0E69" + "\u0E6B\x05\u0166\xB4\x02\u0E6A\u0E68\x03\x02\x02\x02\u0E6B\u0E6E\x03\x02" + "\x02\x02\u0E6C\u0E6A\x03\x02\x02\x02\u0E6C\u0E6D\x03\x02\x02\x02\u0E6D" + "\u0161\x03\x02\x02\x02\u0E6E\u0E6C\x03\x02\x02\x02\u0E6F\u0E70\x07\x88" + "\x02\x02\u0E70\u0E71\x07\x04\x02\x02\u0E71\u0E72\x05\u0106\x84\x02\u0E72" + "\u0E73\x07\x05\x02\x02\u0E73\u0E79\x03\x02\x02\x02\u0E74\u0E79\x05\u0166" + "\xB4\x02\u0E75\u0E79\x07r\x02\x02\u0E76\u0E79\x07\xA1\x02\x02\u0E77\u0E79" + "\x07\xF5\x02\x02\u0E78\u0E6F\x03\x02\x02\x02\u0E78\u0E74\x03\x02\x02\x02" + "\u0E78\u0E75\x03\x02\x02\x02\u0E78\u0E76\x03\x02\x02\x02\u0E78\u0E77\x03" + "\x02\x02\x02\u0E79\u0163\x03\x02\x02\x02\u0E7A\u0E7B\x05\u0166\xB4\x02" + "\u0E7B\u0165\x03\x02\x02\x02\u0E7C\u0E81\x05\u016C\xB7\x02\u0E7D\u0E7E" + "\x07\x07\x02\x02\u0E7E\u0E80\x05\u016C\xB7\x02\u0E7F\u0E7D\x03\x02\x02" + "\x02\u0E80\u0E83\x03\x02\x02\x02\u0E81\u0E7F\x03\x02\x02\x02\u0E81\u0E82" + "\x03\x02\x02\x02\u0E82\u0167\x03\x02\x02\x02\u0E83\u0E81\x03\x02\x02\x02" + "\u0E84\u0E85\x05\u016C\xB7\x02\u0E85\u0E86\x05\u016A\xB6\x02\u0E86\u0169" + "\x03\x02\x02\x02\u0E87\u0E88\x07\u0164\x02\x02\u0E88\u0E8A\x05\u016C\xB7" + "\x02\u0E89\u0E87\x03\x02\x02\x02\u0E8A\u0E8B\x03\x02\x02\x02\u0E8B\u0E89" + "\x03\x02\x02\x02\u0E8B\u0E8C\x03\x02\x02\x02\u0E8C\u0E8F\x03\x02\x02\x02" + "\u0E8D\u0E8F\x03\x02\x02\x02\u0E8E\u0E89\x03\x02\x02\x02\u0E8E\u0E8D\x03" + "\x02\x02\x02\u0E8F\u016B\x03\x02\x02\x02\u0E90\u0E94\x05\u016E\xB8\x02" + "\u0E91\u0E92\x06\xB7\x12\x02\u0E92\u0E94\x05\u0180\xC1\x02\u0E93\u0E90" + "\x03\x02\x02\x02\u0E93\u0E91\x03\x02\x02\x02\u0E94\u016D\x03\x02\x02\x02" + "\u0E95\u0E9C\x07\u017E\x02\x02\u0E96\u0E9C\x05\u0170\xB9\x02\u0E97\u0E98" + "\x06\xB8\x13\x02\u0E98\u0E9C\x05\u017E\xC0\x02\u0E99\u0E9A\x06\xB8\x14" + "\x02\u0E9A\u0E9C\x05\u0182\xC2\x02\u0E9B\u0E95\x03"; private static readonly _serializedATNSegment7: string = "\x02\x02\x02\u0E9B\u0E96\x03\x02\x02\x02\u0E9B\u0E97\x03\x02\x02\x02\u0E9B" + "\u0E99\x03\x02\x02\x02\u0E9C\u016F\x03\x02\x02\x02\u0E9D\u0EA1\x07\u017F" + "\x02\x02\u0E9E\u0E9F\x06\xB9\x15\x02\u0E9F\u0EA1\x07\u0174\x02\x02\u0EA0" + "\u0E9D\x03\x02\x02\x02\u0EA0\u0E9E\x03\x02\x02\x02\u0EA1\u0171\x03\x02" + "\x02\x02\u0EA2\u0EA3\x07\u017F\x02\x02\u0EA3\u0173\x03\x02\x02\x02\u0EA4" + "\u0EA6\x06\xBB\x16\x02\u0EA5\u0EA7\x07\u0164\x02\x02\u0EA6\u0EA5\x03\x02" + "\x02\x02\u0EA6\u0EA7\x03\x02\x02\x02\u0EA7\u0EA8\x03\x02\x02\x02\u0EA8" + "\u0ED0\x07\u0179\x02\x02\u0EA9\u0EAB\x06\xBB\x17\x02\u0EAA\u0EAC\x07\u0164" + "\x02\x02\u0EAB\u0EAA\x03\x02\x02\x02\u0EAB\u0EAC\x03\x02\x02\x02\u0EAC" + "\u0EAD\x03\x02\x02\x02\u0EAD\u0ED0\x07\u017A\x02\x02\u0EAE\u0EB0\x06\xBB" + "\x18\x02\u0EAF\u0EB1\x07\u0164\x02\x02\u0EB0\u0EAF\x03\x02\x02\x02\u0EB0" + "\u0EB1\x03\x02\x02\x02\u0EB1\u0EB2\x03\x02\x02\x02\u0EB2\u0ED0\t;\x02" + "\x02\u0EB3\u0EB5\x07\u0164\x02\x02\u0EB4\u0EB3\x03\x02\x02\x02\u0EB4\u0EB5" + "\x03\x02\x02\x02\u0EB5\u0EB6\x03\x02\x02\x02\u0EB6\u0ED0\x07\u0178\x02" + "\x02\u0EB7\u0EB9\x07\u0164\x02\x02\u0EB8\u0EB7\x03\x02\x02\x02\u0EB8\u0EB9" + "\x03\x02\x02\x02\u0EB9\u0EBA\x03\x02\x02\x02\u0EBA\u0ED0\x07\u0175\x02" + "\x02\u0EBB\u0EBD\x07\u0164\x02\x02\u0EBC\u0EBB\x03\x02\x02\x02\u0EBC\u0EBD" + "\x03\x02\x02\x02\u0EBD\u0EBE\x03\x02\x02\x02\u0EBE\u0ED0\x07\u0176\x02" + "\x02\u0EBF\u0EC1\x07\u0164\x02\x02\u0EC0\u0EBF\x03\x02\x02\x02\u0EC0\u0EC1" + "\x03\x02\x02\x02\u0EC1\u0EC2\x03\x02\x02\x02\u0EC2\u0ED0\x07\u0177\x02" + "\x02\u0EC3\u0EC5\x07\u0164\x02\x02\u0EC4\u0EC3\x03\x02\x02\x02\u0EC4\u0EC5" + "\x03\x02\x02\x02\u0EC5\u0EC6\x03\x02\x02\x02\u0EC6\u0ED0\x07\u017C\x02" + "\x02\u0EC7\u0EC9\x07\u0164\x02\x02\u0EC8\u0EC7\x03\x02\x02\x02\u0EC8\u0EC9" + "\x03\x02\x02\x02\u0EC9\u0ECA\x03\x02\x02\x02\u0ECA\u0ED0\x07\u017B\x02" + "\x02\u0ECB\u0ECD\x07\u0164\x02\x02\u0ECC\u0ECB\x03\x02\x02\x02\u0ECC\u0ECD" + "\x03\x02\x02\x02\u0ECD\u0ECE\x03\x02\x02\x02\u0ECE\u0ED0\x07\u017D\x02" + "\x02\u0ECF\u0EA4\x03\x02\x02\x02\u0ECF\u0EA9\x03\x02\x02\x02\u0ECF\u0EAE" + "\x03\x02\x02\x02\u0ECF\u0EB4\x03\x02\x02\x02\u0ECF\u0EB8\x03\x02\x02\x02" + "\u0ECF\u0EBC\x03\x02\x02\x02\u0ECF\u0EC0\x03\x02\x02\x02\u0ECF\u0EC4\x03" + "\x02\x02\x02\u0ECF\u0EC8\x03\x02\x02\x02\u0ECF\u0ECC\x03\x02\x02\x02\u0ED0" + "\u0175\x03\x02\x02\x02\u0ED1\u0ED2\x07\u013A\x02\x02\u0ED2\u0EDD\x05\u0138" + "\x9D\x02\u0ED3\u0EDD\x05\x1A\x0E\x02\u0ED4\u0EDD\x05\u0134\x9B\x02\u0ED5" + "\u0ED6\t<\x02\x02\u0ED6\u0ED7\x07\xC2\x02\x02\u0ED7\u0EDD\x07\xC3\x02" + "\x02\u0ED8\u0ED9\x07\u0108\x02\x02\u0ED9\u0EDD\x05\u0140\xA1\x02\u0EDA" + "\u0EDB\x07a\x02\x02\u0EDB\u0EDD\x07T\x02\x02\u0EDC\u0ED1\x03\x02\x02\x02" + "\u0EDC\u0ED3\x03\x02\x02\x02\u0EDC\u0ED4\x03\x02\x02\x02\u0EDC\u0ED5\x03" + "\x02\x02\x02\u0EDC\u0ED8\x03\x02\x02\x02\u0EDC\u0EDA\x03\x02\x02\x02\u0EDD" + "\u0177\x03\x02\x02\x02\u0EDE\u0EE2\x07\u0173\x02\x02\u0EDF\u0EE0\x06\xBD" + "\x19\x02\u0EE0\u0EE2\x07\u0174\x02\x02\u0EE1\u0EDE\x03\x02\x02\x02\u0EE1" + "\u0EDF\x03\x02\x02\x02\u0EE2\u0179\x03\x02\x02\x02\u0EE3\u0EE6\x05\u0178" + "\xBD\x02\u0EE4\u0EE6\x07\xC3\x02\x02\u0EE5\u0EE3\x03\x02\x02\x02\u0EE5" + "\u0EE4\x03\x02\x02\x02\u0EE6\u017B\x03\x02\x02\x02\u0EE7\u0EEA\x07\u0178" + "\x02\x02\u0EE8\u0EEA\x05\u0178\xBD\x02\u0EE9\u0EE7\x03\x02\x02\x02\u0EE9" + "\u0EE8\x03\x02\x02\x02\u0EEA\u017D\x03\x02\x02\x02\u0EEB\u0EEC\t=\x02" + "\x02\u0EEC\u017F\x03\x02\x02\x02\u0EED\u0EEE\t>\x02\x02\u0EEE\u0181\x03" + "\x02\x02\x02\u0EEF\u0EF0\t?\x02\x02\u0EF0\u0183\x03\x02\x02\x02\u01F5" + "\u0187\u018E\u0192\u019F\u01A4\u01AC\u01AE\u01C1\u01C5\u01CB\u01CE\u01D1" + "\u01D8\u01DB\u01DF\u01E2\u01E7\u01F2\u01F4\u01FC\u01FF\u0203\u0206\u020C" + "\u0217\u021D\u0222\u0243\u024F\u0258\u0263\u026E\u0273\u027C\u0280\u0286" + "\u028A\u028F\u0295\u02A1\u02A9\u02AF\u02BA\u02BE\u02C3\u02D2\u02D6\u02DD" + "\u02E1\u02E7\u02F5\u02F9\u02FE\u0304\u0307\u030A\u030E\u0312\u031A\u031C" + "\u0325\u0328\u0331\u0336\u033C\u0343\u0346\u034A\u0355\u0358\u035C\u0360" + "\u0366\u0369\u036D\u0370\u0376\u037B\u037F\u0386\u0389\u038C\u0393\u0398" + "\u03A1\u03A9\u03AF\u03B2\u03B5\u03BB\u03BF\u03C4\u03C7\u03CB\u03CD\u03D5" + "\u03DD\u03E0\u03E5\u03EB\u03F0\u03F3\u03F7\u03FA\u03FE\u041A\u041D\u0421" + "\u0427\u042A\u042D\u0432\u043A\u043F\u0445\u044B\u044E\u0455\u045C\u0464" + "\u0475\u0490\u0493\u0499\u04A2\u04AB\u04B1\u04B6\u04BB\u04C2\u04C7\u04CC" + "\u04D4\u04D7\u04DB\u04E7\u04EB\u04F2\u0566\u056E\u0576\u057F\u0589\u058D" + "\u0590\u0594\u059A\u05A6\u05B2\u05B7\u05C0\u05C8\u05CD\u05CF\u05D4\u05D9" + "\u05DD\u05E0\u05E5\u05EA\u05F3\u05F8\u05FB\u0600\u0604\u0609\u060B\u060F" + "\u0618\u0620\u0626\u0631\u0638\u0641\u0646\u0649\u065F\u0661\u066A\u0671" + "\u0674\u067B\u067F\u0685\u068D\u0694\u0697\u069F\u06AA\u06B5\u06BD\u06C3" + "\u06CF\u06D6\u06DD\u06E9\u06F1\u06F7\u06FD\u0700\u0714\u071D\u0720\u0729" + "\u072C\u0735\u0738\u0741\u0744\u0747\u074C\u074E\u0752\u075E\u0765\u076C" + "\u076F\u0771\u077D\u0781\u0785\u078B\u078F\u0797\u079B\u079E\u07A1\u07A4" + "\u07A8\u07AC\u07B1\u07B5\u07B8\u07BB\u07BE\u07C2\u07C7\u07CB\u07CE\u07D1" + "\u07D4\u07D6\u07DC\u07E3\u07E8\u07EB\u07EE\u07F2\u07FC\u0800\u0802\u0805" + "\u0809\u080F\u0813\u081E\u0828\u082C\u0838\u0844\u0853\u0858\u085E\u0865" + "\u0875\u087A\u0887\u088C\u0894\u089A\u089E\u08A1\u08A6\u08AD\u08B3\u08BC" + "\u08C6\u08D5\u08DA\u08DC\u08E0\u08E9\u08F6\u08FB\u08FF\u0907\u090A\u090E" + "\u091C\u0929\u092E\u0932\u0935\u0939\u093F\u0942\u0949\u0955\u0960\u096D" + "\u0978\u097D\u0985\u098A\u0998\u09A1\u09A4\u09A9\u09B0\u09B3\u09B8\u09BE" + "\u09C2\u09C7\u09CC\u09D0\u09D6\u09DA\u09DD\u09E2\u09E5\u09EA\u09EE\u09F1" + "\u09F4\u09FA\u09FF\u0A06\u0A09\u0A1B\u0A1D\u0A20\u0A2B\u0A34\u0A3B\u0A43" + "\u0A4A\u0A4E\u0A51\u0A59\u0A61\u0A67\u0A6F\u0A77\u0A7E\u0A85\u0A87\u0A94" + "\u0A9A\u0A9C\u0AA6\u0AAC\u0AAE\u0AB6\u0ABA\u0AC3\u0AC6\u0ACC\u0AD0\u0AD2" + "\u0ADB\u0AE7\u0AE9\u0AF0\u0AF7\u0AFD\u0B03\u0B05\u0B0C\u0B14\u0B1C\u0B22" + "\u0B27\u0B2E\u0B34\u0B38\u0B3A\u0B41\u0B4A\u0B51\u0B5B\u0B60\u0B64\u0B6E" + "\u0B75\u0B82\u0B84\u0B8C\u0B8E\u0B92\u0B9A\u0BA3\u0BA9\u0BB1\u0BB6\u0BC2" + "\u0BC7\u0BCA\u0BD0\u0BD4\u0BD9\u0BDE\u0BE3\u0BE9\u0BFE\u0C00\u0C0B\u0C17" + "\u0C23\u0C27\u0C30\u0C34\u0C46\u0C49\u0C51\u0C5A\u0C63\u0C7A\u0C8A\u0C91" + "\u0C94\u0C9D\u0CA1\u0CA5\u0CB1\u0CCA\u0CD1\u0CD4\u0CE3\u0CF8\u0CFC\u0CFE" + "\u0D08\u0D0A\u0D14\u0D23\u0D25\u0D32\u0D36\u0D3D\u0D42\u0D4A\u0D4F\u0D58" + "\u0D78\u0D89\u0D8D\u0D93\u0D99\u0DA2\u0DA6\u0DA8\u0DAF\u0DB7\u0DBF\u0DCC" + "\u0DD3\u0DD6\u0DDD\u0DE5\u0DED\u0DFB\u0E00\u0E05\u0E08\u0E15\u0E29\u0E33" + "\u0E36\u0E3F\u0E42\u0E44\u0E47\u0E4A\u0E5C\u0E65\u0E6C\u0E78\u0E81\u0E8B" + "\u0E8E\u0E93\u0E9B\u0EA0\u0EA6\u0EAB\u0EB0\u0EB4\u0EB8\u0EBC\u0EC0\u0EC4" + "\u0EC8\u0ECC\u0ECF\u0EDC\u0EE1\u0EE5\u0EE9"; public static readonly _serializedATN: string = Utils.join( [ SparkSqlParser._serializedATNSegment0, SparkSqlParser._serializedATNSegment1, SparkSqlParser._serializedATNSegment2, SparkSqlParser._serializedATNSegment3, SparkSqlParser._serializedATNSegment4, SparkSqlParser._serializedATNSegment5, SparkSqlParser._serializedATNSegment6, SparkSqlParser._serializedATNSegment7, ], "", ); public static __ATN: ATN; public static get _ATN(): ATN { if (!SparkSqlParser.__ATN) { SparkSqlParser.__ATN = new ATNDeserializer().deserialize(Utils.toCharArray(SparkSqlParser._serializedATN)); } return SparkSqlParser.__ATN; } } export class ProgramContext extends ParserRuleContext { public EOF(): TerminalNode { return this.getToken(SparkSqlParser.EOF, 0); } public singleStatement(): SingleStatementContext[]; public singleStatement(i: number): SingleStatementContext; public singleStatement(i?: number): SingleStatementContext | SingleStatementContext[] { if (i === undefined) { return this.getRuleContexts(SingleStatementContext); } else { return this.getRuleContext(i, SingleStatementContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_program; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterProgram) { listener.enterProgram(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitProgram) { listener.exitProgram(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitProgram) { return visitor.visitProgram(this); } else { return visitor.visitChildren(this); } } } export class SingleStatementContext extends ParserRuleContext { public statement(): StatementContext { return this.getRuleContext(0, StatementContext); } public SEMICOLON(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.SEMICOLON, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_singleStatement; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterSingleStatement) { listener.enterSingleStatement(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitSingleStatement) { listener.exitSingleStatement(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitSingleStatement) { return visitor.visitSingleStatement(this); } else { return visitor.visitChildren(this); } } } export class StatementContext extends ParserRuleContext { public _pattern!: StringLitContext; public _target!: TableNameCreateContext; public _source!: TableNameContext; public _tableProps!: PropertyListContext; public _table!: TableNameContext; public _column!: MultipartIdentifierContext; public _colName!: MultipartIdentifierContext; public _className!: StringLitContext; public _ns!: DbSchemaNameContext; public _key!: PropertyKeyContext; public _legacy!: MultipartIdentifierContext; public _option!: Token; public _options!: PropertyListContext; public _path!: StringLitContext; public _op!: Token; public _indexType!: IdentifierContext; public query(): QueryContext | undefined { return this.tryGetRuleContext(0, QueryContext); } public dmlStatementNoWith(): DmlStatementNoWithContext | undefined { return this.tryGetRuleContext(0, DmlStatementNoWithContext); } public ctes(): CtesContext | undefined { return this.tryGetRuleContext(0, CtesContext); } public KW_USE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_USE, 0); } public dbSchemaName(): DbSchemaNameContext | undefined { return this.tryGetRuleContext(0, DbSchemaNameContext); } public dbSchema(): DbSchemaContext | undefined { return this.tryGetRuleContext(0, DbSchemaContext); } public KW_SET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SET, 0); } public KW_CATALOG(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CATALOG, 0); } public identifier(): IdentifierContext[]; public identifier(i: number): IdentifierContext; public identifier(i?: number): IdentifierContext | IdentifierContext[] { if (i === undefined) { return this.getRuleContexts(IdentifierContext); } else { return this.getRuleContext(i, IdentifierContext); } } public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } public KW_CREATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CREATE, 0); } public dbSchemaNameCreate(): DbSchemaNameCreateContext | undefined { return this.tryGetRuleContext(0, DbSchemaNameCreateContext); } public ifNotExists(): IfNotExistsContext | undefined { return this.tryGetRuleContext(0, IfNotExistsContext); } public commentSpec(): CommentSpecContext[]; public commentSpec(i: number): CommentSpecContext; public commentSpec(i?: number): CommentSpecContext | CommentSpecContext[] { if (i === undefined) { return this.getRuleContexts(CommentSpecContext); } else { return this.getRuleContext(i, CommentSpecContext); } } public locationSpec(): LocationSpecContext[]; public locationSpec(i: number): LocationSpecContext; public locationSpec(i?: number): LocationSpecContext | LocationSpecContext[] { if (i === undefined) { return this.getRuleContexts(LocationSpecContext); } else { return this.getRuleContext(i, LocationSpecContext); } } public KW_WITH(): TerminalNode[]; public KW_WITH(i: number): TerminalNode; public KW_WITH(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_WITH); } else { return this.getToken(SparkSqlParser.KW_WITH, i); } } public propertyList(): PropertyListContext[]; public propertyList(i: number): PropertyListContext; public propertyList(i?: number): PropertyListContext | PropertyListContext[] { if (i === undefined) { return this.getRuleContexts(PropertyListContext); } else { return this.getRuleContext(i, PropertyListContext); } } public KW_DBPROPERTIES(): TerminalNode[]; public KW_DBPROPERTIES(i: number): TerminalNode; public KW_DBPROPERTIES(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_DBPROPERTIES); } else { return this.getToken(SparkSqlParser.KW_DBPROPERTIES, i); } } public KW_PROPERTIES(): TerminalNode[]; public KW_PROPERTIES(i: number): TerminalNode; public KW_PROPERTIES(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_PROPERTIES); } else { return this.getToken(SparkSqlParser.KW_PROPERTIES, i); } } public KW_ALTER(): TerminalNode[]; public KW_ALTER(i: number): TerminalNode; public KW_ALTER(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_ALTER); } else { return this.getToken(SparkSqlParser.KW_ALTER, i); } } public KW_DROP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DROP, 0); } public ifExists(): IfExistsContext | undefined { return this.tryGetRuleContext(0, IfExistsContext); } public KW_RESTRICT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RESTRICT, 0); } public KW_CASCADE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CASCADE, 0); } public KW_SHOW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SHOW, 0); } public dbSchemas(): DbSchemasContext | undefined { return this.tryGetRuleContext(0, DbSchemasContext); } public multipartIdentifier(): MultipartIdentifierContext | undefined { return this.tryGetRuleContext(0, MultipartIdentifierContext); } public KW_FROM(): TerminalNode[]; public KW_FROM(i: number): TerminalNode; public KW_FROM(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_FROM); } else { return this.getToken(SparkSqlParser.KW_FROM, i); } } public KW_IN(): TerminalNode[]; public KW_IN(i: number): TerminalNode; public KW_IN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_IN); } else { return this.getToken(SparkSqlParser.KW_IN, i); } } public KW_LIKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LIKE, 0); } public createTableHeader(): CreateTableHeaderContext | undefined { return this.tryGetRuleContext(0, CreateTableHeaderContext); } public createTableClauses(): CreateTableClausesContext | undefined { return this.tryGetRuleContext(0, CreateTableClausesContext); } public LEFT_PAREN(): TerminalNode[]; public LEFT_PAREN(i: number): TerminalNode; public LEFT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.LEFT_PAREN); } else { return this.getToken(SparkSqlParser.LEFT_PAREN, i); } } public createOrReplaceTableColTypeList(): CreateOrReplaceTableColTypeListContext | undefined { return this.tryGetRuleContext(0, CreateOrReplaceTableColTypeListContext); } public RIGHT_PAREN(): TerminalNode[]; public RIGHT_PAREN(i: number): TerminalNode; public RIGHT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.RIGHT_PAREN); } else { return this.getToken(SparkSqlParser.RIGHT_PAREN, i); } } public tableProvider(): TableProviderContext[]; public tableProvider(i: number): TableProviderContext; public tableProvider(i?: number): TableProviderContext | TableProviderContext[] { if (i === undefined) { return this.getRuleContexts(TableProviderContext); } else { return this.getRuleContext(i, TableProviderContext); } } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public KW_TABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TABLE, 0); } public tableNameCreate(): TableNameCreateContext | undefined { return this.tryGetRuleContext(0, TableNameCreateContext); } public tableName(): TableNameContext | undefined { return this.tryGetRuleContext(0, TableNameContext); } public rowFormat(): RowFormatContext[]; public rowFormat(i: number): RowFormatContext; public rowFormat(i?: number): RowFormatContext | RowFormatContext[] { if (i === undefined) { return this.getRuleContexts(RowFormatContext); } else { return this.getRuleContext(i, RowFormatContext); } } public createFileFormat(): CreateFileFormatContext[]; public createFileFormat(i: number): CreateFileFormatContext; public createFileFormat(i?: number): CreateFileFormatContext | CreateFileFormatContext[] { if (i === undefined) { return this.getRuleContexts(CreateFileFormatContext); } else { return this.getRuleContext(i, CreateFileFormatContext); } } public KW_TBLPROPERTIES(): TerminalNode[]; public KW_TBLPROPERTIES(i: number): TerminalNode; public KW_TBLPROPERTIES(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_TBLPROPERTIES); } else { return this.getToken(SparkSqlParser.KW_TBLPROPERTIES, i); } } public replaceTableHeader(): ReplaceTableHeaderContext | undefined { return this.tryGetRuleContext(0, ReplaceTableHeaderContext); } public KW_ANALYZE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANALYZE, 0); } public KW_COMPUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMPUTE, 0); } public KW_STATISTICS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STATISTICS, 0); } public partitionSpec(): PartitionSpecContext[]; public partitionSpec(i: number): PartitionSpecContext; public partitionSpec(i?: number): PartitionSpecContext | PartitionSpecContext[] { if (i === undefined) { return this.getRuleContexts(PartitionSpecContext); } else { return this.getRuleContext(i, PartitionSpecContext); } } public KW_FOR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FOR, 0); } public KW_COLUMNS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COLUMNS, 0); } public identifierSeq(): IdentifierSeqContext | undefined { return this.tryGetRuleContext(0, IdentifierSeqContext); } public KW_ALL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALL, 0); } public KW_TABLES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TABLES, 0); } public KW_ADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ADD, 0); } public qualifiedColTypeWithPositionList(): QualifiedColTypeWithPositionListContext | undefined { return this.tryGetRuleContext(0, QualifiedColTypeWithPositionListContext); } public KW_COLUMN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COLUMN, 0); } public KW_RENAME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RENAME, 0); } public KW_TO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TO, 0); } public errorCapturingIdentifier(): ErrorCapturingIdentifierContext | undefined { return this.tryGetRuleContext(0, ErrorCapturingIdentifierContext); } public multipartIdentifierList(): MultipartIdentifierListContext | undefined { return this.tryGetRuleContext(0, MultipartIdentifierListContext); } public KW_VIEW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VIEW, 0); } public viewName(): ViewNameContext | undefined { return this.tryGetRuleContext(0, ViewNameContext); } public KW_UNSET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNSET, 0); } public KW_CHANGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CHANGE, 0); } public alterColumnAction(): AlterColumnActionContext | undefined { return this.tryGetRuleContext(0, AlterColumnActionContext); } public colType(): ColTypeContext | undefined { return this.tryGetRuleContext(0, ColTypeContext); } public colPosition(): ColPositionContext | undefined { return this.tryGetRuleContext(0, ColPositionContext); } public KW_REPLACE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPLACE, 0); } public KW_SERDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SERDE, 0); } public KW_SERDEPROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SERDEPROPERTIES, 0); } public partitionSpecLocation(): PartitionSpecLocationContext[]; public partitionSpecLocation(i: number): PartitionSpecLocationContext; public partitionSpecLocation(i?: number): PartitionSpecLocationContext | PartitionSpecLocationContext[] { if (i === undefined) { return this.getRuleContexts(PartitionSpecLocationContext); } else { return this.getRuleContext(i, PartitionSpecLocationContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } public KW_PURGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PURGE, 0); } public KW_RECOVER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RECOVER, 0); } public KW_PARTITIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PARTITIONS, 0); } public viewNameCreate(): ViewNameCreateContext | undefined { return this.tryGetRuleContext(0, ViewNameCreateContext); } public KW_OR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OR, 0); } public KW_TEMPORARY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TEMPORARY, 0); } public identifierCommentList(): IdentifierCommentListContext | undefined { return this.tryGetRuleContext(0, IdentifierCommentListContext); } public KW_PARTITIONED(): TerminalNode[]; public KW_PARTITIONED(i: number): TerminalNode; public KW_PARTITIONED(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_PARTITIONED); } else { return this.getToken(SparkSqlParser.KW_PARTITIONED, i); } } public KW_ON(): TerminalNode[]; public KW_ON(i: number): TerminalNode; public KW_ON(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_ON); } else { return this.getToken(SparkSqlParser.KW_ON, i); } } public identifierList(): IdentifierListContext[]; public identifierList(i: number): IdentifierListContext; public identifierList(i?: number): IdentifierListContext | IdentifierListContext[] { if (i === undefined) { return this.getRuleContexts(IdentifierListContext); } else { return this.getRuleContext(i, IdentifierListContext); } } public KW_GLOBAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GLOBAL, 0); } public colTypeList(): ColTypeListContext | undefined { return this.tryGetRuleContext(0, ColTypeListContext); } public KW_OPTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OPTIONS, 0); } public KW_FUNCTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FUNCTION, 0); } public functionNameCreate(): FunctionNameCreateContext | undefined { return this.tryGetRuleContext(0, FunctionNameCreateContext); } public KW_USING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_USING, 0); } public resource(): ResourceContext[]; public resource(i: number): ResourceContext; public resource(i?: number): ResourceContext | ResourceContext[] { if (i === undefined) { return this.getRuleContexts(ResourceContext); } else { return this.getRuleContext(i, ResourceContext); } } public functionName(): FunctionNameContext | undefined { return this.tryGetRuleContext(0, FunctionNameContext); } public KW_DECLARE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DECLARE, 0); } public KW_VARIABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VARIABLE, 0); } public dataType(): DataTypeContext | undefined { return this.tryGetRuleContext(0, DataTypeContext); } public variableDefaultExpression(): VariableDefaultExpressionContext | undefined { return this.tryGetRuleContext(0, VariableDefaultExpressionContext); } public KW_EXPLAIN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXPLAIN, 0); } public statement(): StatementContext | undefined { return this.tryGetRuleContext(0, StatementContext); } public KW_LOGICAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOGICAL, 0); } public KW_FORMATTED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FORMATTED, 0); } public KW_EXTENDED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXTENDED, 0); } public KW_CODEGEN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CODEGEN, 0); } public KW_COST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COST, 0); } public propertyKey(): PropertyKeyContext | undefined { return this.tryGetRuleContext(0, PropertyKeyContext); } public KW_VIEWS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VIEWS, 0); } public KW_FUNCTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FUNCTIONS, 0); } public functionKind(): FunctionKindContext | undefined { return this.tryGetRuleContext(0, FunctionKindContext); } public KW_CURRENT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT, 0); } public KW_CATALOGS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CATALOGS, 0); } public describeFuncName(): DescribeFuncNameContext | undefined { return this.tryGetRuleContext(0, DescribeFuncNameContext); } public KW_DESC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DESC, 0); } public KW_DESCRIBE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DESCRIBE, 0); } public KW_DATABASE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATABASE, 0); } public describeColName(): DescribeColNameContext | undefined { return this.tryGetRuleContext(0, DescribeColNameContext); } public KW_QUERY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_QUERY, 0); } public KW_COMMENT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMMENT, 0); } public KW_IS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IS, 0); } public comment(): CommentContext | undefined { return this.tryGetRuleContext(0, CommentContext); } public KW_REFRESH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REFRESH, 0); } public KW_CACHE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CACHE, 0); } public KW_LAZY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LAZY, 0); } public KW_UNCACHE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNCACHE, 0); } public KW_CLEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CLEAR, 0); } public KW_LOAD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOAD, 0); } public KW_DATA(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATA, 0); } public KW_INPATH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INPATH, 0); } public KW_INTO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTO, 0); } public KW_LOCAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCAL, 0); } public KW_OVERWRITE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVERWRITE, 0); } public KW_TRUNCATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRUNCATE, 0); } public KW_REPAIR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPAIR, 0); } public KW_MSCK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MSCK, 0); } public KW_SYNC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYNC, 0); } public KW_LIST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LIST, 0); } public KW_ROLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLE, 0); } public KW_TIME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIME, 0); } public KW_ZONE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ZONE, 0); } public interval(): IntervalContext | undefined { return this.tryGetRuleContext(0, IntervalContext); } public timezone(): TimezoneContext | undefined { return this.tryGetRuleContext(0, TimezoneContext); } public assignmentList(): AssignmentListContext | undefined { return this.tryGetRuleContext(0, AssignmentListContext); } public KW_VAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VAR, 0); } public EQ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.EQ, 0); } public configKey(): ConfigKeyContext | undefined { return this.tryGetRuleContext(0, ConfigKeyContext); } public configValue(): ConfigValueContext | undefined { return this.tryGetRuleContext(0, ConfigValueContext); } public KW_RESET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RESET, 0); } public KW_INDEX(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INDEX, 0); } public multipartIdentifierPropertyList(): MultipartIdentifierPropertyListContext | undefined { return this.tryGetRuleContext(0, MultipartIdentifierPropertyListContext); } public unsupportedHiveNativeCommands(): UnsupportedHiveNativeCommandsContext | undefined { return this.tryGetRuleContext(0, UnsupportedHiveNativeCommandsContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_statement; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterStatement) { listener.enterStatement(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitStatement) { listener.exitStatement(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitStatement) { return visitor.visitStatement(this); } else { return visitor.visitChildren(this); } } } export class TimezoneContext extends ParserRuleContext { public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } public KW_LOCAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCAL, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_timezone; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTimezone) { listener.enterTimezone(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTimezone) { listener.exitTimezone(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTimezone) { return visitor.visitTimezone(this); } else { return visitor.visitChildren(this); } } } export class ConfigKeyContext extends ParserRuleContext { public quotedIdentifier(): QuotedIdentifierContext { return this.getRuleContext(0, QuotedIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_configKey; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterConfigKey) { listener.enterConfigKey(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitConfigKey) { listener.exitConfigKey(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitConfigKey) { return visitor.visitConfigKey(this); } else { return visitor.visitChildren(this); } } } export class ConfigValueContext extends ParserRuleContext { public backQuotedIdentifier(): BackQuotedIdentifierContext { return this.getRuleContext(0, BackQuotedIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_configValue; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterConfigValue) { listener.enterConfigValue(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitConfigValue) { listener.exitConfigValue(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitConfigValue) { return visitor.visitConfigValue(this); } else { return visitor.visitChildren(this); } } } export class UnsupportedHiveNativeCommandsContext extends ParserRuleContext { public _kw1!: Token; public _kw2!: Token; public _kw3!: Token; public _kw4!: Token; public _kw5!: Token; public _kw6!: Token; public KW_CREATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CREATE, 0); } public KW_ROLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLE, 0); } public KW_DROP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DROP, 0); } public KW_GRANT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GRANT, 0); } public KW_REVOKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REVOKE, 0); } public KW_SHOW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SHOW, 0); } public KW_PRINCIPALS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PRINCIPALS, 0); } public KW_ROLES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLES, 0); } public KW_CURRENT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT, 0); } public KW_EXPORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXPORT, 0); } public KW_TABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TABLE, 0); } public KW_IMPORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IMPORT, 0); } public KW_COMPACTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMPACTIONS, 0); } public KW_TRANSACTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRANSACTIONS, 0); } public KW_INDEXES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INDEXES, 0); } public KW_LOCKS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCKS, 0); } public KW_INDEX(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INDEX, 0); } public KW_ALTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALTER, 0); } public KW_LOCK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCK, 0); } public KW_DATABASE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATABASE, 0); } public KW_UNLOCK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNLOCK, 0); } public KW_TEMPORARY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TEMPORARY, 0); } public KW_MACRO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MACRO, 0); } public tableName(): TableNameContext | undefined { return this.tryGetRuleContext(0, TableNameContext); } public KW_NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NOT, 0); } public KW_CLUSTERED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CLUSTERED, 0); } public KW_BY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BY, 0); } public KW_SORTED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SORTED, 0); } public KW_SKEWED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SKEWED, 0); } public KW_STORED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STORED, 0); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public KW_DIRECTORIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIRECTORIES, 0); } public KW_SET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SET, 0); } public KW_LOCATION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCATION, 0); } public KW_EXCHANGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXCHANGE, 0); } public KW_PARTITION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PARTITION, 0); } public KW_ARCHIVE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ARCHIVE, 0); } public KW_UNARCHIVE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNARCHIVE, 0); } public KW_TOUCH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TOUCH, 0); } public KW_COMPACT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMPACT, 0); } public partitionSpec(): PartitionSpecContext | undefined { return this.tryGetRuleContext(0, PartitionSpecContext); } public KW_CONCATENATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CONCATENATE, 0); } public KW_FILEFORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FILEFORMAT, 0); } public KW_REPLACE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPLACE, 0); } public KW_COLUMNS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COLUMNS, 0); } public KW_START(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_START, 0); } public KW_TRANSACTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRANSACTION, 0); } public KW_COMMIT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMMIT, 0); } public KW_ROLLBACK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLLBACK, 0); } public KW_DFS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DFS, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unsupportedHiveNativeCommands; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnsupportedHiveNativeCommands) { listener.enterUnsupportedHiveNativeCommands(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnsupportedHiveNativeCommands) { listener.exitUnsupportedHiveNativeCommands(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnsupportedHiveNativeCommands) { return visitor.visitUnsupportedHiveNativeCommands(this); } else { return visitor.visitChildren(this); } } } export class CreateTableHeaderContext extends ParserRuleContext { public KW_CREATE(): TerminalNode { return this.getToken(SparkSqlParser.KW_CREATE, 0); } public KW_TABLE(): TerminalNode { return this.getToken(SparkSqlParser.KW_TABLE, 0); } public tableNameCreate(): TableNameCreateContext { return this.getRuleContext(0, TableNameCreateContext); } public KW_TEMPORARY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TEMPORARY, 0); } public KW_EXTERNAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXTERNAL, 0); } public ifNotExists(): IfNotExistsContext | undefined { return this.tryGetRuleContext(0, IfNotExistsContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_createTableHeader; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterCreateTableHeader) { listener.enterCreateTableHeader(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitCreateTableHeader) { listener.exitCreateTableHeader(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitCreateTableHeader) { return visitor.visitCreateTableHeader(this); } else { return visitor.visitChildren(this); } } } export class ReplaceTableHeaderContext extends ParserRuleContext { public KW_REPLACE(): TerminalNode { return this.getToken(SparkSqlParser.KW_REPLACE, 0); } public KW_TABLE(): TerminalNode { return this.getToken(SparkSqlParser.KW_TABLE, 0); } public tableNameCreate(): TableNameCreateContext { return this.getRuleContext(0, TableNameCreateContext); } public KW_CREATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CREATE, 0); } public KW_OR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OR, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_replaceTableHeader; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterReplaceTableHeader) { listener.enterReplaceTableHeader(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitReplaceTableHeader) { listener.exitReplaceTableHeader(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitReplaceTableHeader) { return visitor.visitReplaceTableHeader(this); } else { return visitor.visitChildren(this); } } } export class BucketSpecContext extends ParserRuleContext { public KW_CLUSTERED(): TerminalNode { return this.getToken(SparkSqlParser.KW_CLUSTERED, 0); } public KW_BY(): TerminalNode[]; public KW_BY(i: number): TerminalNode; public KW_BY(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_BY); } else { return this.getToken(SparkSqlParser.KW_BY, i); } } public identifierList(): IdentifierListContext { return this.getRuleContext(0, IdentifierListContext); } public KW_INTO(): TerminalNode { return this.getToken(SparkSqlParser.KW_INTO, 0); } public INTEGER_VALUE(): TerminalNode { return this.getToken(SparkSqlParser.INTEGER_VALUE, 0); } public KW_BUCKETS(): TerminalNode { return this.getToken(SparkSqlParser.KW_BUCKETS, 0); } public KW_SORTED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SORTED, 0); } public orderedIdentifierList(): OrderedIdentifierListContext | undefined { return this.tryGetRuleContext(0, OrderedIdentifierListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_bucketSpec; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterBucketSpec) { listener.enterBucketSpec(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitBucketSpec) { listener.exitBucketSpec(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitBucketSpec) { return visitor.visitBucketSpec(this); } else { return visitor.visitChildren(this); } } } export class SkewSpecContext extends ParserRuleContext { public KW_SKEWED(): TerminalNode { return this.getToken(SparkSqlParser.KW_SKEWED, 0); } public KW_BY(): TerminalNode { return this.getToken(SparkSqlParser.KW_BY, 0); } public identifierList(): IdentifierListContext { return this.getRuleContext(0, IdentifierListContext); } public KW_ON(): TerminalNode { return this.getToken(SparkSqlParser.KW_ON, 0); } public constantList(): ConstantListContext | undefined { return this.tryGetRuleContext(0, ConstantListContext); } public nestedConstantList(): NestedConstantListContext | undefined { return this.tryGetRuleContext(0, NestedConstantListContext); } public KW_STORED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STORED, 0); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public KW_DIRECTORIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIRECTORIES, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_skewSpec; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterSkewSpec) { listener.enterSkewSpec(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitSkewSpec) { listener.exitSkewSpec(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitSkewSpec) { return visitor.visitSkewSpec(this); } else { return visitor.visitChildren(this); } } } export class LocationSpecContext extends ParserRuleContext { public KW_LOCATION(): TerminalNode { return this.getToken(SparkSqlParser.KW_LOCATION, 0); } public stringLit(): StringLitContext { return this.getRuleContext(0, StringLitContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_locationSpec; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterLocationSpec) { listener.enterLocationSpec(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitLocationSpec) { listener.exitLocationSpec(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitLocationSpec) { return visitor.visitLocationSpec(this); } else { return visitor.visitChildren(this); } } } export class CommentSpecContext extends ParserRuleContext { public KW_COMMENT(): TerminalNode { return this.getToken(SparkSqlParser.KW_COMMENT, 0); } public stringLit(): StringLitContext { return this.getRuleContext(0, StringLitContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_commentSpec; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterCommentSpec) { listener.enterCommentSpec(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitCommentSpec) { listener.exitCommentSpec(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitCommentSpec) { return visitor.visitCommentSpec(this); } else { return visitor.visitChildren(this); } } } export class QueryContext extends ParserRuleContext { public queryTerm(): QueryTermContext { return this.getRuleContext(0, QueryTermContext); } public queryOrganization(): QueryOrganizationContext { return this.getRuleContext(0, QueryOrganizationContext); } public ctes(): CtesContext | undefined { return this.tryGetRuleContext(0, CtesContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_query; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterQuery) { listener.enterQuery(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitQuery) { listener.exitQuery(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitQuery) { return visitor.visitQuery(this); } else { return visitor.visitChildren(this); } } } export class InsertIntoContext extends ParserRuleContext { public _path!: StringLitContext; public _options!: PropertyListContext; public KW_INSERT(): TerminalNode { return this.getToken(SparkSqlParser.KW_INSERT, 0); } public KW_OVERWRITE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVERWRITE, 0); } public tableName(): TableNameContext | undefined { return this.tryGetRuleContext(0, TableNameContext); } public KW_TABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TABLE, 0); } public partitionSpec(): PartitionSpecContext | undefined { return this.tryGetRuleContext(0, PartitionSpecContext); } public identifierList(): IdentifierListContext | undefined { return this.tryGetRuleContext(0, IdentifierListContext); } public KW_BY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BY, 0); } public KW_NAME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NAME, 0); } public ifNotExists(): IfNotExistsContext | undefined { return this.tryGetRuleContext(0, IfNotExistsContext); } public KW_INTO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTO, 0); } public KW_REPLACE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPLACE, 0); } public whereClause(): WhereClauseContext | undefined { return this.tryGetRuleContext(0, WhereClauseContext); } public KW_DIRECTORY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIRECTORY, 0); } public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } public KW_LOCAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCAL, 0); } public rowFormat(): RowFormatContext | undefined { return this.tryGetRuleContext(0, RowFormatContext); } public createFileFormat(): CreateFileFormatContext | undefined { return this.tryGetRuleContext(0, CreateFileFormatContext); } public tableProvider(): TableProviderContext | undefined { return this.tryGetRuleContext(0, TableProviderContext); } public KW_OPTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OPTIONS, 0); } public propertyList(): PropertyListContext | undefined { return this.tryGetRuleContext(0, PropertyListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_insertInto; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterInsertInto) { listener.enterInsertInto(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitInsertInto) { listener.exitInsertInto(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitInsertInto) { return visitor.visitInsertInto(this); } else { return visitor.visitChildren(this); } } } export class PartitionSpecLocationContext extends ParserRuleContext { public partitionSpec(): PartitionSpecContext { return this.getRuleContext(0, PartitionSpecContext); } public locationSpec(): LocationSpecContext | undefined { return this.tryGetRuleContext(0, LocationSpecContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_partitionSpecLocation; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPartitionSpecLocation) { listener.enterPartitionSpecLocation(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPartitionSpecLocation) { listener.exitPartitionSpecLocation(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPartitionSpecLocation) { return visitor.visitPartitionSpecLocation(this); } else { return visitor.visitChildren(this); } } } export class PartitionSpecContext extends ParserRuleContext { public KW_PARTITION(): TerminalNode { return this.getToken(SparkSqlParser.KW_PARTITION, 0); } public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public partitionVal(): PartitionValContext[]; public partitionVal(i: number): PartitionValContext; public partitionVal(i?: number): PartitionValContext | PartitionValContext[] { if (i === undefined) { return this.getRuleContexts(PartitionValContext); } else { return this.getRuleContext(i, PartitionValContext); } } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_partitionSpec; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPartitionSpec) { listener.enterPartitionSpec(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPartitionSpec) { listener.exitPartitionSpec(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPartitionSpec) { return visitor.visitPartitionSpec(this); } else { return visitor.visitChildren(this); } } } export class PartitionValContext extends ParserRuleContext { public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } public EQ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.EQ, 0); } public constant(): ConstantContext | undefined { return this.tryGetRuleContext(0, ConstantContext); } public KW_DEFAULT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEFAULT, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_partitionVal; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPartitionVal) { listener.enterPartitionVal(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPartitionVal) { listener.exitPartitionVal(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPartitionVal) { return visitor.visitPartitionVal(this); } else { return visitor.visitChildren(this); } } } export class DbSchemaContext extends ParserRuleContext { public KW_NAMESPACE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NAMESPACE, 0); } public KW_DATABASE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATABASE, 0); } public KW_SCHEMA(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SCHEMA, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_dbSchema; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterDbSchema) { listener.enterDbSchema(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitDbSchema) { listener.exitDbSchema(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitDbSchema) { return visitor.visitDbSchema(this); } else { return visitor.visitChildren(this); } } } export class DbSchemasContext extends ParserRuleContext { public KW_NAMESPACES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NAMESPACES, 0); } public KW_DATABASES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATABASES, 0); } public KW_SCHEMAS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SCHEMAS, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_dbSchemas; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterDbSchemas) { listener.enterDbSchemas(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitDbSchemas) { listener.exitDbSchemas(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitDbSchemas) { return visitor.visitDbSchemas(this); } else { return visitor.visitChildren(this); } } } export class DescribeFuncNameContext extends ParserRuleContext { public identifierReference(): IdentifierReferenceContext | undefined { return this.tryGetRuleContext(0, IdentifierReferenceContext); } public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } public comparisonOperator(): ComparisonOperatorContext | undefined { return this.tryGetRuleContext(0, ComparisonOperatorContext); } public arithmeticOperator(): ArithmeticOperatorContext | undefined { return this.tryGetRuleContext(0, ArithmeticOperatorContext); } public predicateOperator(): PredicateOperatorContext | undefined { return this.tryGetRuleContext(0, PredicateOperatorContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_describeFuncName; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterDescribeFuncName) { listener.enterDescribeFuncName(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitDescribeFuncName) { listener.exitDescribeFuncName(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitDescribeFuncName) { return visitor.visitDescribeFuncName(this); } else { return visitor.visitChildren(this); } } } export class DescribeColNameContext extends ParserRuleContext { public _identifier!: IdentifierContext; public _nameParts: IdentifierContext[] = []; public identifier(): IdentifierContext[]; public identifier(i: number): IdentifierContext; public identifier(i?: number): IdentifierContext | IdentifierContext[] { if (i === undefined) { return this.getRuleContexts(IdentifierContext); } else { return this.getRuleContext(i, IdentifierContext); } } public DOT(): TerminalNode[]; public DOT(i: number): TerminalNode; public DOT(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.DOT); } else { return this.getToken(SparkSqlParser.DOT, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_describeColName; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterDescribeColName) { listener.enterDescribeColName(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitDescribeColName) { listener.exitDescribeColName(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitDescribeColName) { return visitor.visitDescribeColName(this); } else { return visitor.visitChildren(this); } } } export class CtesContext extends ParserRuleContext { public KW_WITH(): TerminalNode { return this.getToken(SparkSqlParser.KW_WITH, 0); } public namedQuery(): NamedQueryContext[]; public namedQuery(i: number): NamedQueryContext; public namedQuery(i?: number): NamedQueryContext | NamedQueryContext[] { if (i === undefined) { return this.getRuleContexts(NamedQueryContext); } else { return this.getRuleContext(i, NamedQueryContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_ctes; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterCtes) { listener.enterCtes(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitCtes) { listener.exitCtes(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitCtes) { return visitor.visitCtes(this); } else { return visitor.visitChildren(this); } } } export class NamedQueryContext extends ParserRuleContext { public _name!: ErrorCapturingIdentifierContext; public _columnAliases!: IdentifierListContext; public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public query(): QueryContext { return this.getRuleContext(0, QueryContext); } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public errorCapturingIdentifier(): ErrorCapturingIdentifierContext { return this.getRuleContext(0, ErrorCapturingIdentifierContext); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public identifierList(): IdentifierListContext | undefined { return this.tryGetRuleContext(0, IdentifierListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_namedQuery; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNamedQuery) { listener.enterNamedQuery(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNamedQuery) { listener.exitNamedQuery(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNamedQuery) { return visitor.visitNamedQuery(this); } else { return visitor.visitChildren(this); } } } export class TableProviderContext extends ParserRuleContext { public KW_USING(): TerminalNode { return this.getToken(SparkSqlParser.KW_USING, 0); } public multipartIdentifier(): MultipartIdentifierContext { return this.getRuleContext(0, MultipartIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_tableProvider; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTableProvider) { listener.enterTableProvider(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTableProvider) { listener.exitTableProvider(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTableProvider) { return visitor.visitTableProvider(this); } else { return visitor.visitChildren(this); } } } export class CreateTableClausesContext extends ParserRuleContext { public _options!: ExpressionPropertyListContext; public _partitioning!: PartitionFieldListContext; public _tableProps!: PropertyListContext; public skewSpec(): SkewSpecContext[]; public skewSpec(i: number): SkewSpecContext; public skewSpec(i?: number): SkewSpecContext | SkewSpecContext[] { if (i === undefined) { return this.getRuleContexts(SkewSpecContext); } else { return this.getRuleContext(i, SkewSpecContext); } } public bucketSpec(): BucketSpecContext[]; public bucketSpec(i: number): BucketSpecContext; public bucketSpec(i?: number): BucketSpecContext | BucketSpecContext[] { if (i === undefined) { return this.getRuleContexts(BucketSpecContext); } else { return this.getRuleContext(i, BucketSpecContext); } } public rowFormat(): RowFormatContext[]; public rowFormat(i: number): RowFormatContext; public rowFormat(i?: number): RowFormatContext | RowFormatContext[] { if (i === undefined) { return this.getRuleContexts(RowFormatContext); } else { return this.getRuleContext(i, RowFormatContext); } } public createFileFormat(): CreateFileFormatContext[]; public createFileFormat(i: number): CreateFileFormatContext; public createFileFormat(i?: number): CreateFileFormatContext | CreateFileFormatContext[] { if (i === undefined) { return this.getRuleContexts(CreateFileFormatContext); } else { return this.getRuleContext(i, CreateFileFormatContext); } } public locationSpec(): LocationSpecContext[]; public locationSpec(i: number): LocationSpecContext; public locationSpec(i?: number): LocationSpecContext | LocationSpecContext[] { if (i === undefined) { return this.getRuleContexts(LocationSpecContext); } else { return this.getRuleContext(i, LocationSpecContext); } } public commentSpec(): CommentSpecContext[]; public commentSpec(i: number): CommentSpecContext; public commentSpec(i?: number): CommentSpecContext | CommentSpecContext[] { if (i === undefined) { return this.getRuleContexts(CommentSpecContext); } else { return this.getRuleContext(i, CommentSpecContext); } } public KW_OPTIONS(): TerminalNode[]; public KW_OPTIONS(i: number): TerminalNode; public KW_OPTIONS(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_OPTIONS); } else { return this.getToken(SparkSqlParser.KW_OPTIONS, i); } } public KW_PARTITIONED(): TerminalNode[]; public KW_PARTITIONED(i: number): TerminalNode; public KW_PARTITIONED(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_PARTITIONED); } else { return this.getToken(SparkSqlParser.KW_PARTITIONED, i); } } public KW_BY(): TerminalNode[]; public KW_BY(i: number): TerminalNode; public KW_BY(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_BY); } else { return this.getToken(SparkSqlParser.KW_BY, i); } } public KW_TBLPROPERTIES(): TerminalNode[]; public KW_TBLPROPERTIES(i: number): TerminalNode; public KW_TBLPROPERTIES(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_TBLPROPERTIES); } else { return this.getToken(SparkSqlParser.KW_TBLPROPERTIES, i); } } public expressionPropertyList(): ExpressionPropertyListContext[]; public expressionPropertyList(i: number): ExpressionPropertyListContext; public expressionPropertyList(i?: number): ExpressionPropertyListContext | ExpressionPropertyListContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionPropertyListContext); } else { return this.getRuleContext(i, ExpressionPropertyListContext); } } public partitionFieldList(): PartitionFieldListContext[]; public partitionFieldList(i: number): PartitionFieldListContext; public partitionFieldList(i?: number): PartitionFieldListContext | PartitionFieldListContext[] { if (i === undefined) { return this.getRuleContexts(PartitionFieldListContext); } else { return this.getRuleContext(i, PartitionFieldListContext); } } public propertyList(): PropertyListContext[]; public propertyList(i: number): PropertyListContext; public propertyList(i?: number): PropertyListContext | PropertyListContext[] { if (i === undefined) { return this.getRuleContexts(PropertyListContext); } else { return this.getRuleContext(i, PropertyListContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_createTableClauses; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterCreateTableClauses) { listener.enterCreateTableClauses(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitCreateTableClauses) { listener.exitCreateTableClauses(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitCreateTableClauses) { return visitor.visitCreateTableClauses(this); } else { return visitor.visitChildren(this); } } } export class PropertyListContext extends ParserRuleContext { public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public property(): PropertyContext[]; public property(i: number): PropertyContext; public property(i?: number): PropertyContext | PropertyContext[] { if (i === undefined) { return this.getRuleContexts(PropertyContext); } else { return this.getRuleContext(i, PropertyContext); } } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_propertyList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPropertyList) { listener.enterPropertyList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPropertyList) { listener.exitPropertyList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPropertyList) { return visitor.visitPropertyList(this); } else { return visitor.visitChildren(this); } } } export class PropertyContext extends ParserRuleContext { public _key!: PropertyKeyContext; public _value!: PropertyValueContext; public propertyKey(): PropertyKeyContext { return this.getRuleContext(0, PropertyKeyContext); } public propertyValue(): PropertyValueContext | undefined { return this.tryGetRuleContext(0, PropertyValueContext); } public EQ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.EQ, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_property; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterProperty) { listener.enterProperty(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitProperty) { listener.exitProperty(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitProperty) { return visitor.visitProperty(this); } else { return visitor.visitChildren(this); } } } export class PropertyKeyContext extends ParserRuleContext { public identifier(): IdentifierContext[]; public identifier(i: number): IdentifierContext; public identifier(i?: number): IdentifierContext | IdentifierContext[] { if (i === undefined) { return this.getRuleContexts(IdentifierContext); } else { return this.getRuleContext(i, IdentifierContext); } } public DOT(): TerminalNode[]; public DOT(i: number): TerminalNode; public DOT(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.DOT); } else { return this.getToken(SparkSqlParser.DOT, i); } } public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_propertyKey; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPropertyKey) { listener.enterPropertyKey(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPropertyKey) { listener.exitPropertyKey(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPropertyKey) { return visitor.visitPropertyKey(this); } else { return visitor.visitChildren(this); } } } export class PropertyValueContext extends ParserRuleContext { public INTEGER_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.INTEGER_VALUE, 0); } public DECIMAL_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.DECIMAL_VALUE, 0); } public booleanValue(): BooleanValueContext | undefined { return this.tryGetRuleContext(0, BooleanValueContext); } public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_propertyValue; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPropertyValue) { listener.enterPropertyValue(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPropertyValue) { listener.exitPropertyValue(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPropertyValue) { return visitor.visitPropertyValue(this); } else { return visitor.visitChildren(this); } } } export class ExpressionPropertyListContext extends ParserRuleContext { public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public expressionProperty(): ExpressionPropertyContext[]; public expressionProperty(i: number): ExpressionPropertyContext; public expressionProperty(i?: number): ExpressionPropertyContext | ExpressionPropertyContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionPropertyContext); } else { return this.getRuleContext(i, ExpressionPropertyContext); } } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_expressionPropertyList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterExpressionPropertyList) { listener.enterExpressionPropertyList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitExpressionPropertyList) { listener.exitExpressionPropertyList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitExpressionPropertyList) { return visitor.visitExpressionPropertyList(this); } else { return visitor.visitChildren(this); } } } export class ExpressionPropertyContext extends ParserRuleContext { public _key!: PropertyKeyContext; public _value!: ExpressionContext; public propertyKey(): PropertyKeyContext { return this.getRuleContext(0, PropertyKeyContext); } public expression(): ExpressionContext | undefined { return this.tryGetRuleContext(0, ExpressionContext); } public EQ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.EQ, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_expressionProperty; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterExpressionProperty) { listener.enterExpressionProperty(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitExpressionProperty) { listener.exitExpressionProperty(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitExpressionProperty) { return visitor.visitExpressionProperty(this); } else { return visitor.visitChildren(this); } } } export class ConstantListContext extends ParserRuleContext { public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public constant(): ConstantContext[]; public constant(i: number): ConstantContext; public constant(i?: number): ConstantContext | ConstantContext[] { if (i === undefined) { return this.getRuleContexts(ConstantContext); } else { return this.getRuleContext(i, ConstantContext); } } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_constantList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterConstantList) { listener.enterConstantList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitConstantList) { listener.exitConstantList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitConstantList) { return visitor.visitConstantList(this); } else { return visitor.visitChildren(this); } } } export class NestedConstantListContext extends ParserRuleContext { public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public constantList(): ConstantListContext[]; public constantList(i: number): ConstantListContext; public constantList(i?: number): ConstantListContext | ConstantListContext[] { if (i === undefined) { return this.getRuleContexts(ConstantListContext); } else { return this.getRuleContext(i, ConstantListContext); } } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_nestedConstantList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNestedConstantList) { listener.enterNestedConstantList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNestedConstantList) { listener.exitNestedConstantList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNestedConstantList) { return visitor.visitNestedConstantList(this); } else { return visitor.visitChildren(this); } } } export class CreateFileFormatContext extends ParserRuleContext { public KW_STORED(): TerminalNode { return this.getToken(SparkSqlParser.KW_STORED, 0); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public fileFormat(): FileFormatContext | undefined { return this.tryGetRuleContext(0, FileFormatContext); } public KW_BY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BY, 0); } public storageHandler(): StorageHandlerContext | undefined { return this.tryGetRuleContext(0, StorageHandlerContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_createFileFormat; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterCreateFileFormat) { listener.enterCreateFileFormat(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitCreateFileFormat) { listener.exitCreateFileFormat(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitCreateFileFormat) { return visitor.visitCreateFileFormat(this); } else { return visitor.visitChildren(this); } } } export class FileFormatContext extends ParserRuleContext { public _inFmt!: StringLitContext; public _outFmt!: StringLitContext; public KW_INPUTFORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INPUTFORMAT, 0); } public KW_OUTPUTFORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OUTPUTFORMAT, 0); } public stringLit(): StringLitContext[]; public stringLit(i: number): StringLitContext; public stringLit(i?: number): StringLitContext | StringLitContext[] { if (i === undefined) { return this.getRuleContexts(StringLitContext); } else { return this.getRuleContext(i, StringLitContext); } } public identifier(): IdentifierContext | undefined { return this.tryGetRuleContext(0, IdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_fileFormat; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFileFormat) { listener.enterFileFormat(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFileFormat) { listener.exitFileFormat(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFileFormat) { return visitor.visitFileFormat(this); } else { return visitor.visitChildren(this); } } } export class StorageHandlerContext extends ParserRuleContext { public stringLit(): StringLitContext { return this.getRuleContext(0, StringLitContext); } public KW_WITH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WITH, 0); } public KW_SERDEPROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SERDEPROPERTIES, 0); } public propertyList(): PropertyListContext | undefined { return this.tryGetRuleContext(0, PropertyListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_storageHandler; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterStorageHandler) { listener.enterStorageHandler(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitStorageHandler) { listener.exitStorageHandler(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitStorageHandler) { return visitor.visitStorageHandler(this); } else { return visitor.visitChildren(this); } } } export class ResourceContext extends ParserRuleContext { public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } public stringLit(): StringLitContext { return this.getRuleContext(0, StringLitContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_resource; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterResource) { listener.enterResource(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitResource) { listener.exitResource(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitResource) { return visitor.visitResource(this); } else { return visitor.visitChildren(this); } } } export class DmlStatementNoWithContext extends ParserRuleContext { public _target!: TableNameContext; public _targetAlias!: TableAliasContext; public _source!: IdentifierReferenceContext; public _sourceQuery!: QueryContext; public _sourceAlias!: TableAliasContext; public _mergeCondition!: BooleanExpressionContext; public insertInto(): InsertIntoContext | undefined { return this.tryGetRuleContext(0, InsertIntoContext); } public query(): QueryContext | undefined { return this.tryGetRuleContext(0, QueryContext); } public fromClause(): FromClauseContext | undefined { return this.tryGetRuleContext(0, FromClauseContext); } public multiInsertQueryBody(): MultiInsertQueryBodyContext[]; public multiInsertQueryBody(i: number): MultiInsertQueryBodyContext; public multiInsertQueryBody(i?: number): MultiInsertQueryBodyContext | MultiInsertQueryBodyContext[] { if (i === undefined) { return this.getRuleContexts(MultiInsertQueryBodyContext); } else { return this.getRuleContext(i, MultiInsertQueryBodyContext); } } public KW_DELETE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DELETE, 0); } public KW_FROM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FROM, 0); } public tableName(): TableNameContext | undefined { return this.tryGetRuleContext(0, TableNameContext); } public tableAlias(): TableAliasContext[]; public tableAlias(i: number): TableAliasContext; public tableAlias(i?: number): TableAliasContext | TableAliasContext[] { if (i === undefined) { return this.getRuleContexts(TableAliasContext); } else { return this.getRuleContext(i, TableAliasContext); } } public whereClause(): WhereClauseContext | undefined { return this.tryGetRuleContext(0, WhereClauseContext); } public KW_UPDATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UPDATE, 0); } public setClause(): SetClauseContext | undefined { return this.tryGetRuleContext(0, SetClauseContext); } public KW_MERGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MERGE, 0); } public KW_INTO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTO, 0); } public KW_USING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_USING, 0); } public KW_ON(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ON, 0); } public booleanExpression(): BooleanExpressionContext | undefined { return this.tryGetRuleContext(0, BooleanExpressionContext); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public identifierReference(): IdentifierReferenceContext | undefined { return this.tryGetRuleContext(0, IdentifierReferenceContext); } public matchedClause(): MatchedClauseContext[]; public matchedClause(i: number): MatchedClauseContext; public matchedClause(i?: number): MatchedClauseContext | MatchedClauseContext[] { if (i === undefined) { return this.getRuleContexts(MatchedClauseContext); } else { return this.getRuleContext(i, MatchedClauseContext); } } public notMatchedClause(): NotMatchedClauseContext[]; public notMatchedClause(i: number): NotMatchedClauseContext; public notMatchedClause(i?: number): NotMatchedClauseContext | NotMatchedClauseContext[] { if (i === undefined) { return this.getRuleContexts(NotMatchedClauseContext); } else { return this.getRuleContext(i, NotMatchedClauseContext); } } public notMatchedBySourceClause(): NotMatchedBySourceClauseContext[]; public notMatchedBySourceClause(i: number): NotMatchedBySourceClauseContext; public notMatchedBySourceClause(i?: number): NotMatchedBySourceClauseContext | NotMatchedBySourceClauseContext[] { if (i === undefined) { return this.getRuleContexts(NotMatchedBySourceClauseContext); } else { return this.getRuleContext(i, NotMatchedBySourceClauseContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_dmlStatementNoWith; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterDmlStatementNoWith) { listener.enterDmlStatementNoWith(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitDmlStatementNoWith) { listener.exitDmlStatementNoWith(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitDmlStatementNoWith) { return visitor.visitDmlStatementNoWith(this); } else { return visitor.visitChildren(this); } } } export class DbSchemaNameContext extends ParserRuleContext { public identifierReference(): IdentifierReferenceContext { return this.getRuleContext(0, IdentifierReferenceContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_dbSchemaName; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterDbSchemaName) { listener.enterDbSchemaName(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitDbSchemaName) { listener.exitDbSchemaName(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitDbSchemaName) { return visitor.visitDbSchemaName(this); } else { return visitor.visitChildren(this); } } } export class DbSchemaNameCreateContext extends ParserRuleContext { public identifierReference(): IdentifierReferenceContext { return this.getRuleContext(0, IdentifierReferenceContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_dbSchemaNameCreate; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterDbSchemaNameCreate) { listener.enterDbSchemaNameCreate(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitDbSchemaNameCreate) { listener.exitDbSchemaNameCreate(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitDbSchemaNameCreate) { return visitor.visitDbSchemaNameCreate(this); } else { return visitor.visitChildren(this); } } } export class TableNameCreateContext extends ParserRuleContext { public tableIdentifier(): TableIdentifierContext { return this.getRuleContext(0, TableIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_tableNameCreate; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTableNameCreate) { listener.enterTableNameCreate(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTableNameCreate) { listener.exitTableNameCreate(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTableNameCreate) { return visitor.visitTableNameCreate(this); } else { return visitor.visitChildren(this); } } } export class TableNameContext extends ParserRuleContext { public tableIdentifier(): TableIdentifierContext { return this.getRuleContext(0, TableIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_tableName; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTableName) { listener.enterTableName(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTableName) { listener.exitTableName(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTableName) { return visitor.visitTableName(this); } else { return visitor.visitChildren(this); } } } export class ViewNameCreateContext extends ParserRuleContext { public viewIdentifier(): ViewIdentifierContext { return this.getRuleContext(0, ViewIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_viewNameCreate; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterViewNameCreate) { listener.enterViewNameCreate(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitViewNameCreate) { listener.exitViewNameCreate(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitViewNameCreate) { return visitor.visitViewNameCreate(this); } else { return visitor.visitChildren(this); } } } export class ViewNameContext extends ParserRuleContext { public viewIdentifier(): ViewIdentifierContext { return this.getRuleContext(0, ViewIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_viewName; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterViewName) { listener.enterViewName(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitViewName) { listener.exitViewName(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitViewName) { return visitor.visitViewName(this); } else { return visitor.visitChildren(this); } } } export class IdentifierReferenceContext extends ParserRuleContext { public KW_IDENTIFIER_KW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IDENTIFIER_KW, 0); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public expression(): ExpressionContext | undefined { return this.tryGetRuleContext(0, ExpressionContext); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public multipartIdentifier(): MultipartIdentifierContext | undefined { return this.tryGetRuleContext(0, MultipartIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_identifierReference; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterIdentifierReference) { listener.enterIdentifierReference(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitIdentifierReference) { listener.exitIdentifierReference(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitIdentifierReference) { return visitor.visitIdentifierReference(this); } else { return visitor.visitChildren(this); } } } export class QueryOrganizationContext extends ParserRuleContext { public _sortItem!: SortItemContext; public _order: SortItemContext[] = []; public _expression!: ExpressionContext; public _clusterBy: ExpressionContext[] = []; public _distributeBy: ExpressionContext[] = []; public _sort: SortItemContext[] = []; public _limit!: ExpressionContext; public _offset!: ExpressionContext; public KW_ORDER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ORDER, 0); } public KW_BY(): TerminalNode[]; public KW_BY(i: number): TerminalNode; public KW_BY(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_BY); } else { return this.getToken(SparkSqlParser.KW_BY, i); } } public KW_CLUSTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CLUSTER, 0); } public KW_DISTRIBUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DISTRIBUTE, 0); } public KW_SORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SORT, 0); } public windowClause(): WindowClauseContext | undefined { return this.tryGetRuleContext(0, WindowClauseContext); } public KW_LIMIT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LIMIT, 0); } public KW_OFFSET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OFFSET, 0); } public sortItem(): SortItemContext[]; public sortItem(i: number): SortItemContext; public sortItem(i?: number): SortItemContext | SortItemContext[] { if (i === undefined) { return this.getRuleContexts(SortItemContext); } else { return this.getRuleContext(i, SortItemContext); } } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public KW_ALL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALL, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_queryOrganization; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterQueryOrganization) { listener.enterQueryOrganization(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitQueryOrganization) { listener.exitQueryOrganization(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitQueryOrganization) { return visitor.visitQueryOrganization(this); } else { return visitor.visitChildren(this); } } } export class MultiInsertQueryBodyContext extends ParserRuleContext { public insertInto(): InsertIntoContext { return this.getRuleContext(0, InsertIntoContext); } public fromStatementBody(): FromStatementBodyContext { return this.getRuleContext(0, FromStatementBodyContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_multiInsertQueryBody; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterMultiInsertQueryBody) { listener.enterMultiInsertQueryBody(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitMultiInsertQueryBody) { listener.exitMultiInsertQueryBody(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitMultiInsertQueryBody) { return visitor.visitMultiInsertQueryBody(this); } else { return visitor.visitChildren(this); } } } export class QueryTermContext extends ParserRuleContext { public _left!: QueryTermContext; public _operator!: Token; public _right!: QueryTermContext; public queryPrimary(): QueryPrimaryContext | undefined { return this.tryGetRuleContext(0, QueryPrimaryContext); } public queryTerm(): QueryTermContext[]; public queryTerm(i: number): QueryTermContext; public queryTerm(i?: number): QueryTermContext | QueryTermContext[] { if (i === undefined) { return this.getRuleContexts(QueryTermContext); } else { return this.getRuleContext(i, QueryTermContext); } } public KW_INTERSECT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTERSECT, 0); } public KW_UNION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNION, 0); } public KW_EXCEPT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXCEPT, 0); } public KW_SETMINUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SETMINUS, 0); } public setQuantifier(): SetQuantifierContext | undefined { return this.tryGetRuleContext(0, SetQuantifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_queryTerm; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterQueryTerm) { listener.enterQueryTerm(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitQueryTerm) { listener.exitQueryTerm(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitQueryTerm) { return visitor.visitQueryTerm(this); } else { return visitor.visitChildren(this); } } } export class QueryPrimaryContext extends ParserRuleContext { public querySpecification(): QuerySpecificationContext | undefined { return this.tryGetRuleContext(0, QuerySpecificationContext); } public fromStatement(): FromStatementContext | undefined { return this.tryGetRuleContext(0, FromStatementContext); } public KW_TABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TABLE, 0); } public tableName(): TableNameContext | undefined { return this.tryGetRuleContext(0, TableNameContext); } public inlineTable(): InlineTableContext | undefined { return this.tryGetRuleContext(0, InlineTableContext); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public query(): QueryContext | undefined { return this.tryGetRuleContext(0, QueryContext); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_queryPrimary; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterQueryPrimary) { listener.enterQueryPrimary(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitQueryPrimary) { listener.exitQueryPrimary(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitQueryPrimary) { return visitor.visitQueryPrimary(this); } else { return visitor.visitChildren(this); } } } export class SortItemContext extends ParserRuleContext { public _ordering!: Token; public _nullOrder!: Token; public expression(): ExpressionContext { return this.getRuleContext(0, ExpressionContext); } public KW_NULLS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULLS, 0); } public KW_ASC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ASC, 0); } public KW_DESC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DESC, 0); } public KW_LAST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LAST, 0); } public KW_FIRST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FIRST, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_sortItem; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterSortItem) { listener.enterSortItem(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitSortItem) { listener.exitSortItem(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitSortItem) { return visitor.visitSortItem(this); } else { return visitor.visitChildren(this); } } } export class FromStatementContext extends ParserRuleContext { public fromClause(): FromClauseContext { return this.getRuleContext(0, FromClauseContext); } public fromStatementBody(): FromStatementBodyContext[]; public fromStatementBody(i: number): FromStatementBodyContext; public fromStatementBody(i?: number): FromStatementBodyContext | FromStatementBodyContext[] { if (i === undefined) { return this.getRuleContexts(FromStatementBodyContext); } else { return this.getRuleContext(i, FromStatementBodyContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_fromStatement; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFromStatement) { listener.enterFromStatement(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFromStatement) { listener.exitFromStatement(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFromStatement) { return visitor.visitFromStatement(this); } else { return visitor.visitChildren(this); } } } export class FromStatementBodyContext extends ParserRuleContext { public transformClause(): TransformClauseContext | undefined { return this.tryGetRuleContext(0, TransformClauseContext); } public queryOrganization(): QueryOrganizationContext { return this.getRuleContext(0, QueryOrganizationContext); } public whereClause(): WhereClauseContext | undefined { return this.tryGetRuleContext(0, WhereClauseContext); } public selectClause(): SelectClauseContext | undefined { return this.tryGetRuleContext(0, SelectClauseContext); } public lateralView(): LateralViewContext[]; public lateralView(i: number): LateralViewContext; public lateralView(i?: number): LateralViewContext | LateralViewContext[] { if (i === undefined) { return this.getRuleContexts(LateralViewContext); } else { return this.getRuleContext(i, LateralViewContext); } } public aggregationClause(): AggregationClauseContext | undefined { return this.tryGetRuleContext(0, AggregationClauseContext); } public havingClause(): HavingClauseContext | undefined { return this.tryGetRuleContext(0, HavingClauseContext); } public windowClause(): WindowClauseContext | undefined { return this.tryGetRuleContext(0, WindowClauseContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_fromStatementBody; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFromStatementBody) { listener.enterFromStatementBody(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFromStatementBody) { listener.exitFromStatementBody(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFromStatementBody) { return visitor.visitFromStatementBody(this); } else { return visitor.visitChildren(this); } } } export class QuerySpecificationContext extends ParserRuleContext { public transformClause(): TransformClauseContext | undefined { return this.tryGetRuleContext(0, TransformClauseContext); } public fromClause(): FromClauseContext | undefined { return this.tryGetRuleContext(0, FromClauseContext); } public lateralView(): LateralViewContext[]; public lateralView(i: number): LateralViewContext; public lateralView(i?: number): LateralViewContext | LateralViewContext[] { if (i === undefined) { return this.getRuleContexts(LateralViewContext); } else { return this.getRuleContext(i, LateralViewContext); } } public whereClause(): WhereClauseContext | undefined { return this.tryGetRuleContext(0, WhereClauseContext); } public aggregationClause(): AggregationClauseContext | undefined { return this.tryGetRuleContext(0, AggregationClauseContext); } public havingClause(): HavingClauseContext | undefined { return this.tryGetRuleContext(0, HavingClauseContext); } public windowClause(): WindowClauseContext | undefined { return this.tryGetRuleContext(0, WindowClauseContext); } public selectClause(): SelectClauseContext | undefined { return this.tryGetRuleContext(0, SelectClauseContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_querySpecification; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterQuerySpecification) { listener.enterQuerySpecification(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitQuerySpecification) { listener.exitQuerySpecification(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitQuerySpecification) { return visitor.visitQuerySpecification(this); } else { return visitor.visitChildren(this); } } } export class TransformClauseContext extends ParserRuleContext { public _kind!: Token; public _inRowFormat!: RowFormatContext; public _recordWriter!: StringLitContext; public _script!: StringLitContext; public _outRowFormat!: RowFormatContext; public _recordReader!: StringLitContext; public KW_USING(): TerminalNode { return this.getToken(SparkSqlParser.KW_USING, 0); } public stringLit(): StringLitContext[]; public stringLit(i: number): StringLitContext; public stringLit(i?: number): StringLitContext | StringLitContext[] { if (i === undefined) { return this.getRuleContexts(StringLitContext); } else { return this.getRuleContext(i, StringLitContext); } } public KW_SELECT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SELECT, 0); } public LEFT_PAREN(): TerminalNode[]; public LEFT_PAREN(i: number): TerminalNode; public LEFT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.LEFT_PAREN); } else { return this.getToken(SparkSqlParser.LEFT_PAREN, i); } } public expressionSeq(): ExpressionSeqContext | undefined { return this.tryGetRuleContext(0, ExpressionSeqContext); } public RIGHT_PAREN(): TerminalNode[]; public RIGHT_PAREN(i: number): TerminalNode; public RIGHT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.RIGHT_PAREN); } else { return this.getToken(SparkSqlParser.RIGHT_PAREN, i); } } public KW_TRANSFORM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRANSFORM, 0); } public KW_MAP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MAP, 0); } public KW_REDUCE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REDUCE, 0); } public KW_RECORDWRITER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RECORDWRITER, 0); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public KW_RECORDREADER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RECORDREADER, 0); } public rowFormat(): RowFormatContext[]; public rowFormat(i: number): RowFormatContext; public rowFormat(i?: number): RowFormatContext | RowFormatContext[] { if (i === undefined) { return this.getRuleContexts(RowFormatContext); } else { return this.getRuleContext(i, RowFormatContext); } } public setQuantifier(): SetQuantifierContext | undefined { return this.tryGetRuleContext(0, SetQuantifierContext); } public identifierSeq(): IdentifierSeqContext | undefined { return this.tryGetRuleContext(0, IdentifierSeqContext); } public colTypeList(): ColTypeListContext | undefined { return this.tryGetRuleContext(0, ColTypeListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_transformClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTransformClause) { listener.enterTransformClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTransformClause) { listener.exitTransformClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTransformClause) { return visitor.visitTransformClause(this); } else { return visitor.visitChildren(this); } } } export class SelectClauseContext extends ParserRuleContext { public _hint!: HintContext; public _hints: HintContext[] = []; public KW_SELECT(): TerminalNode { return this.getToken(SparkSqlParser.KW_SELECT, 0); } public namedExpressionSeq(): NamedExpressionSeqContext { return this.getRuleContext(0, NamedExpressionSeqContext); } public setQuantifier(): SetQuantifierContext | undefined { return this.tryGetRuleContext(0, SetQuantifierContext); } public hint(): HintContext[]; public hint(i: number): HintContext; public hint(i?: number): HintContext | HintContext[] { if (i === undefined) { return this.getRuleContexts(HintContext); } else { return this.getRuleContext(i, HintContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_selectClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterSelectClause) { listener.enterSelectClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitSelectClause) { listener.exitSelectClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitSelectClause) { return visitor.visitSelectClause(this); } else { return visitor.visitChildren(this); } } } export class SetClauseContext extends ParserRuleContext { public KW_SET(): TerminalNode { return this.getToken(SparkSqlParser.KW_SET, 0); } public assignmentList(): AssignmentListContext { return this.getRuleContext(0, AssignmentListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_setClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterSetClause) { listener.enterSetClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitSetClause) { listener.exitSetClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitSetClause) { return visitor.visitSetClause(this); } else { return visitor.visitChildren(this); } } } export class MatchedClauseContext extends ParserRuleContext { public _matchedCond!: BooleanExpressionContext; public KW_WHEN(): TerminalNode { return this.getToken(SparkSqlParser.KW_WHEN, 0); } public KW_MATCHED(): TerminalNode { return this.getToken(SparkSqlParser.KW_MATCHED, 0); } public KW_THEN(): TerminalNode { return this.getToken(SparkSqlParser.KW_THEN, 0); } public matchedAction(): MatchedActionContext { return this.getRuleContext(0, MatchedActionContext); } public KW_AND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AND, 0); } public booleanExpression(): BooleanExpressionContext | undefined { return this.tryGetRuleContext(0, BooleanExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_matchedClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterMatchedClause) { listener.enterMatchedClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitMatchedClause) { listener.exitMatchedClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitMatchedClause) { return visitor.visitMatchedClause(this); } else { return visitor.visitChildren(this); } } } export class NotMatchedClauseContext extends ParserRuleContext { public _notMatchedCond!: BooleanExpressionContext; public KW_WHEN(): TerminalNode { return this.getToken(SparkSqlParser.KW_WHEN, 0); } public KW_NOT(): TerminalNode { return this.getToken(SparkSqlParser.KW_NOT, 0); } public KW_MATCHED(): TerminalNode { return this.getToken(SparkSqlParser.KW_MATCHED, 0); } public KW_THEN(): TerminalNode { return this.getToken(SparkSqlParser.KW_THEN, 0); } public notMatchedAction(): NotMatchedActionContext { return this.getRuleContext(0, NotMatchedActionContext); } public KW_BY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BY, 0); } public KW_TARGET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TARGET, 0); } public KW_AND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AND, 0); } public booleanExpression(): BooleanExpressionContext | undefined { return this.tryGetRuleContext(0, BooleanExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_notMatchedClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNotMatchedClause) { listener.enterNotMatchedClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNotMatchedClause) { listener.exitNotMatchedClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNotMatchedClause) { return visitor.visitNotMatchedClause(this); } else { return visitor.visitChildren(this); } } } export class NotMatchedBySourceClauseContext extends ParserRuleContext { public _notMatchedBySourceCond!: BooleanExpressionContext; public KW_WHEN(): TerminalNode { return this.getToken(SparkSqlParser.KW_WHEN, 0); } public KW_NOT(): TerminalNode { return this.getToken(SparkSqlParser.KW_NOT, 0); } public KW_MATCHED(): TerminalNode { return this.getToken(SparkSqlParser.KW_MATCHED, 0); } public KW_BY(): TerminalNode { return this.getToken(SparkSqlParser.KW_BY, 0); } public KW_SOURCE(): TerminalNode { return this.getToken(SparkSqlParser.KW_SOURCE, 0); } public KW_THEN(): TerminalNode { return this.getToken(SparkSqlParser.KW_THEN, 0); } public notMatchedBySourceAction(): NotMatchedBySourceActionContext { return this.getRuleContext(0, NotMatchedBySourceActionContext); } public KW_AND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AND, 0); } public booleanExpression(): BooleanExpressionContext | undefined { return this.tryGetRuleContext(0, BooleanExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_notMatchedBySourceClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNotMatchedBySourceClause) { listener.enterNotMatchedBySourceClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNotMatchedBySourceClause) { listener.exitNotMatchedBySourceClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNotMatchedBySourceClause) { return visitor.visitNotMatchedBySourceClause(this); } else { return visitor.visitChildren(this); } } } export class MatchedActionContext extends ParserRuleContext { public KW_DELETE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DELETE, 0); } public KW_UPDATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UPDATE, 0); } public KW_SET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SET, 0); } public ASTERISK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.ASTERISK, 0); } public assignmentList(): AssignmentListContext | undefined { return this.tryGetRuleContext(0, AssignmentListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_matchedAction; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterMatchedAction) { listener.enterMatchedAction(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitMatchedAction) { listener.exitMatchedAction(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitMatchedAction) { return visitor.visitMatchedAction(this); } else { return visitor.visitChildren(this); } } } export class NotMatchedActionContext extends ParserRuleContext { public KW_INSERT(): TerminalNode { return this.getToken(SparkSqlParser.KW_INSERT, 0); } public ASTERISK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.ASTERISK, 0); } public LEFT_PAREN(): TerminalNode[]; public LEFT_PAREN(i: number): TerminalNode; public LEFT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.LEFT_PAREN); } else { return this.getToken(SparkSqlParser.LEFT_PAREN, i); } } public multipartIdentifierList(): MultipartIdentifierListContext | undefined { return this.tryGetRuleContext(0, MultipartIdentifierListContext); } public RIGHT_PAREN(): TerminalNode[]; public RIGHT_PAREN(i: number): TerminalNode; public RIGHT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.RIGHT_PAREN); } else { return this.getToken(SparkSqlParser.RIGHT_PAREN, i); } } public KW_VALUES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VALUES, 0); } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_notMatchedAction; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNotMatchedAction) { listener.enterNotMatchedAction(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNotMatchedAction) { listener.exitNotMatchedAction(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNotMatchedAction) { return visitor.visitNotMatchedAction(this); } else { return visitor.visitChildren(this); } } } export class NotMatchedBySourceActionContext extends ParserRuleContext { public KW_DELETE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DELETE, 0); } public KW_UPDATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UPDATE, 0); } public KW_SET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SET, 0); } public assignmentList(): AssignmentListContext | undefined { return this.tryGetRuleContext(0, AssignmentListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_notMatchedBySourceAction; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNotMatchedBySourceAction) { listener.enterNotMatchedBySourceAction(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNotMatchedBySourceAction) { listener.exitNotMatchedBySourceAction(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNotMatchedBySourceAction) { return visitor.visitNotMatchedBySourceAction(this); } else { return visitor.visitChildren(this); } } } export class AssignmentListContext extends ParserRuleContext { public assignment(): AssignmentContext[]; public assignment(i: number): AssignmentContext; public assignment(i?: number): AssignmentContext | AssignmentContext[] { if (i === undefined) { return this.getRuleContexts(AssignmentContext); } else { return this.getRuleContext(i, AssignmentContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_assignmentList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterAssignmentList) { listener.enterAssignmentList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitAssignmentList) { listener.exitAssignmentList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitAssignmentList) { return visitor.visitAssignmentList(this); } else { return visitor.visitChildren(this); } } } export class AssignmentContext extends ParserRuleContext { public _key!: MultipartIdentifierContext; public _value!: ExpressionContext; public EQ(): TerminalNode { return this.getToken(SparkSqlParser.EQ, 0); } public multipartIdentifier(): MultipartIdentifierContext { return this.getRuleContext(0, MultipartIdentifierContext); } public expression(): ExpressionContext { return this.getRuleContext(0, ExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_assignment; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterAssignment) { listener.enterAssignment(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitAssignment) { listener.exitAssignment(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitAssignment) { return visitor.visitAssignment(this); } else { return visitor.visitChildren(this); } } } export class WhereClauseContext extends ParserRuleContext { public KW_WHERE(): TerminalNode { return this.getToken(SparkSqlParser.KW_WHERE, 0); } public booleanExpression(): BooleanExpressionContext { return this.getRuleContext(0, BooleanExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_whereClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterWhereClause) { listener.enterWhereClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitWhereClause) { listener.exitWhereClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitWhereClause) { return visitor.visitWhereClause(this); } else { return visitor.visitChildren(this); } } } export class HavingClauseContext extends ParserRuleContext { public KW_HAVING(): TerminalNode { return this.getToken(SparkSqlParser.KW_HAVING, 0); } public booleanExpression(): BooleanExpressionContext { return this.getRuleContext(0, BooleanExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_havingClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterHavingClause) { listener.enterHavingClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitHavingClause) { listener.exitHavingClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitHavingClause) { return visitor.visitHavingClause(this); } else { return visitor.visitChildren(this); } } } export class HintContext extends ParserRuleContext { public _hintStatement!: HintStatementContext; public _hintStatements: HintStatementContext[] = []; public HENT_START(): TerminalNode { return this.getToken(SparkSqlParser.HENT_START, 0); } public HENT_END(): TerminalNode { return this.getToken(SparkSqlParser.HENT_END, 0); } public hintStatement(): HintStatementContext[]; public hintStatement(i: number): HintStatementContext; public hintStatement(i?: number): HintStatementContext | HintStatementContext[] { if (i === undefined) { return this.getRuleContexts(HintStatementContext); } else { return this.getRuleContext(i, HintStatementContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_hint; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterHint) { listener.enterHint(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitHint) { listener.exitHint(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitHint) { return visitor.visitHint(this); } else { return visitor.visitChildren(this); } } } export class HintStatementContext extends ParserRuleContext { public _hintName!: IdentifierContext; public _primaryExpression!: PrimaryExpressionContext; public _parameters: PrimaryExpressionContext[] = []; public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public primaryExpression(): PrimaryExpressionContext[]; public primaryExpression(i: number): PrimaryExpressionContext; public primaryExpression(i?: number): PrimaryExpressionContext | PrimaryExpressionContext[] { if (i === undefined) { return this.getRuleContexts(PrimaryExpressionContext); } else { return this.getRuleContext(i, PrimaryExpressionContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_hintStatement; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterHintStatement) { listener.enterHintStatement(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitHintStatement) { listener.exitHintStatement(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitHintStatement) { return visitor.visitHintStatement(this); } else { return visitor.visitChildren(this); } } } export class FromClauseContext extends ParserRuleContext { public KW_FROM(): TerminalNode { return this.getToken(SparkSqlParser.KW_FROM, 0); } public relation(): RelationContext[]; public relation(i: number): RelationContext; public relation(i?: number): RelationContext | RelationContext[] { if (i === undefined) { return this.getRuleContexts(RelationContext); } else { return this.getRuleContext(i, RelationContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } public lateralView(): LateralViewContext[]; public lateralView(i: number): LateralViewContext; public lateralView(i?: number): LateralViewContext | LateralViewContext[] { if (i === undefined) { return this.getRuleContexts(LateralViewContext); } else { return this.getRuleContext(i, LateralViewContext); } } public pivotClause(): PivotClauseContext | undefined { return this.tryGetRuleContext(0, PivotClauseContext); } public unpivotClause(): UnpivotClauseContext | undefined { return this.tryGetRuleContext(0, UnpivotClauseContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_fromClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFromClause) { listener.enterFromClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFromClause) { listener.exitFromClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFromClause) { return visitor.visitFromClause(this); } else { return visitor.visitChildren(this); } } } export class FunctionKindContext extends ParserRuleContext { public KW_USER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_USER, 0); } public KW_SYSTEM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYSTEM, 0); } public KW_ALL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALL, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_functionKind; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFunctionKind) { listener.enterFunctionKind(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFunctionKind) { listener.exitFunctionKind(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFunctionKind) { return visitor.visitFunctionKind(this); } else { return visitor.visitChildren(this); } } } export class TemporalClauseContext extends ParserRuleContext { public _timestamp!: ValueExpressionContext; public KW_AS(): TerminalNode { return this.getToken(SparkSqlParser.KW_AS, 0); } public KW_OF(): TerminalNode { return this.getToken(SparkSqlParser.KW_OF, 0); } public version(): VersionContext | undefined { return this.tryGetRuleContext(0, VersionContext); } public KW_SYSTEM_VERSION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYSTEM_VERSION, 0); } public KW_VERSION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VERSION, 0); } public KW_FOR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FOR, 0); } public KW_SYSTEM_TIME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYSTEM_TIME, 0); } public KW_TIMESTAMP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP, 0); } public valueExpression(): ValueExpressionContext | undefined { return this.tryGetRuleContext(0, ValueExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_temporalClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTemporalClause) { listener.enterTemporalClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTemporalClause) { listener.exitTemporalClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTemporalClause) { return visitor.visitTemporalClause(this); } else { return visitor.visitChildren(this); } } } export class AggregationClauseContext extends ParserRuleContext { public _groupByClause!: GroupByClauseContext; public _groupingExpressionsWithGroupingAnalytics: GroupByClauseContext[] = []; public _expression!: ExpressionContext; public _groupingExpressions: ExpressionContext[] = []; public _kind!: Token; public KW_GROUP(): TerminalNode { return this.getToken(SparkSqlParser.KW_GROUP, 0); } public KW_BY(): TerminalNode { return this.getToken(SparkSqlParser.KW_BY, 0); } public groupByClause(): GroupByClauseContext[]; public groupByClause(i: number): GroupByClauseContext; public groupByClause(i?: number): GroupByClauseContext | GroupByClauseContext[] { if (i === undefined) { return this.getRuleContexts(GroupByClauseContext); } else { return this.getRuleContext(i, GroupByClauseContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public KW_WITH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WITH, 0); } public KW_SETS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SETS, 0); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public groupingSet(): GroupingSetContext[]; public groupingSet(i: number): GroupingSetContext; public groupingSet(i?: number): GroupingSetContext | GroupingSetContext[] { if (i === undefined) { return this.getRuleContexts(GroupingSetContext); } else { return this.getRuleContext(i, GroupingSetContext); } } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public KW_ROLLUP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLLUP, 0); } public KW_CUBE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CUBE, 0); } public KW_GROUPING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GROUPING, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_aggregationClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterAggregationClause) { listener.enterAggregationClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitAggregationClause) { listener.exitAggregationClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitAggregationClause) { return visitor.visitAggregationClause(this); } else { return visitor.visitChildren(this); } } } export class GroupByClauseContext extends ParserRuleContext { public groupingAnalytics(): GroupingAnalyticsContext | undefined { return this.tryGetRuleContext(0, GroupingAnalyticsContext); } public expression(): ExpressionContext | undefined { return this.tryGetRuleContext(0, ExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_groupByClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterGroupByClause) { listener.enterGroupByClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitGroupByClause) { listener.exitGroupByClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitGroupByClause) { return visitor.visitGroupByClause(this); } else { return visitor.visitChildren(this); } } } export class GroupingAnalyticsContext extends ParserRuleContext { public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public groupingSet(): GroupingSetContext[]; public groupingSet(i: number): GroupingSetContext; public groupingSet(i?: number): GroupingSetContext | GroupingSetContext[] { if (i === undefined) { return this.getRuleContexts(GroupingSetContext); } else { return this.getRuleContext(i, GroupingSetContext); } } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public KW_ROLLUP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLLUP, 0); } public KW_CUBE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CUBE, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } public KW_GROUPING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GROUPING, 0); } public KW_SETS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SETS, 0); } public groupingElement(): GroupingElementContext[]; public groupingElement(i: number): GroupingElementContext; public groupingElement(i?: number): GroupingElementContext | GroupingElementContext[] { if (i === undefined) { return this.getRuleContexts(GroupingElementContext); } else { return this.getRuleContext(i, GroupingElementContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_groupingAnalytics; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterGroupingAnalytics) { listener.enterGroupingAnalytics(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitGroupingAnalytics) { listener.exitGroupingAnalytics(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitGroupingAnalytics) { return visitor.visitGroupingAnalytics(this); } else { return visitor.visitChildren(this); } } } export class GroupingElementContext extends ParserRuleContext { public groupingAnalytics(): GroupingAnalyticsContext | undefined { return this.tryGetRuleContext(0, GroupingAnalyticsContext); } public groupingSet(): GroupingSetContext | undefined { return this.tryGetRuleContext(0, GroupingSetContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_groupingElement; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterGroupingElement) { listener.enterGroupingElement(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitGroupingElement) { listener.exitGroupingElement(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitGroupingElement) { return visitor.visitGroupingElement(this); } else { return visitor.visitChildren(this); } } } export class GroupingSetContext extends ParserRuleContext { public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_groupingSet; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterGroupingSet) { listener.enterGroupingSet(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitGroupingSet) { listener.exitGroupingSet(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitGroupingSet) { return visitor.visitGroupingSet(this); } else { return visitor.visitChildren(this); } } } export class PivotClauseContext extends ParserRuleContext { public _aggregates!: NamedExpressionSeqContext; public _pivotValue!: PivotValueContext; public _pivotValues: PivotValueContext[] = []; public KW_PIVOT(): TerminalNode { return this.getToken(SparkSqlParser.KW_PIVOT, 0); } public LEFT_PAREN(): TerminalNode[]; public LEFT_PAREN(i: number): TerminalNode; public LEFT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.LEFT_PAREN); } else { return this.getToken(SparkSqlParser.LEFT_PAREN, i); } } public KW_FOR(): TerminalNode { return this.getToken(SparkSqlParser.KW_FOR, 0); } public pivotColumn(): PivotColumnContext { return this.getRuleContext(0, PivotColumnContext); } public KW_IN(): TerminalNode { return this.getToken(SparkSqlParser.KW_IN, 0); } public RIGHT_PAREN(): TerminalNode[]; public RIGHT_PAREN(i: number): TerminalNode; public RIGHT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.RIGHT_PAREN); } else { return this.getToken(SparkSqlParser.RIGHT_PAREN, i); } } public namedExpressionSeq(): NamedExpressionSeqContext { return this.getRuleContext(0, NamedExpressionSeqContext); } public pivotValue(): PivotValueContext[]; public pivotValue(i: number): PivotValueContext; public pivotValue(i?: number): PivotValueContext | PivotValueContext[] { if (i === undefined) { return this.getRuleContexts(PivotValueContext); } else { return this.getRuleContext(i, PivotValueContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_pivotClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPivotClause) { listener.enterPivotClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPivotClause) { listener.exitPivotClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPivotClause) { return visitor.visitPivotClause(this); } else { return visitor.visitChildren(this); } } } export class PivotColumnContext extends ParserRuleContext { public _identifier!: IdentifierContext; public _identifiers: IdentifierContext[] = []; public identifier(): IdentifierContext[]; public identifier(i: number): IdentifierContext; public identifier(i?: number): IdentifierContext | IdentifierContext[] { if (i === undefined) { return this.getRuleContexts(IdentifierContext); } else { return this.getRuleContext(i, IdentifierContext); } } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_pivotColumn; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPivotColumn) { listener.enterPivotColumn(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPivotColumn) { listener.exitPivotColumn(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPivotColumn) { return visitor.visitPivotColumn(this); } else { return visitor.visitChildren(this); } } } export class PivotValueContext extends ParserRuleContext { public expression(): ExpressionContext { return this.getRuleContext(0, ExpressionContext); } public identifier(): IdentifierContext | undefined { return this.tryGetRuleContext(0, IdentifierContext); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_pivotValue; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPivotValue) { listener.enterPivotValue(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPivotValue) { listener.exitPivotValue(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPivotValue) { return visitor.visitPivotValue(this); } else { return visitor.visitChildren(this); } } } export class UnpivotClauseContext extends ParserRuleContext { public _nullOperator!: UnpivotNullClauseContext; public _operator!: UnpivotOperatorContext; public KW_UNPIVOT(): TerminalNode { return this.getToken(SparkSqlParser.KW_UNPIVOT, 0); } public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public unpivotOperator(): UnpivotOperatorContext { return this.getRuleContext(0, UnpivotOperatorContext); } public identifier(): IdentifierContext | undefined { return this.tryGetRuleContext(0, IdentifierContext); } public unpivotNullClause(): UnpivotNullClauseContext | undefined { return this.tryGetRuleContext(0, UnpivotNullClauseContext); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotClause) { listener.enterUnpivotClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotClause) { listener.exitUnpivotClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotClause) { return visitor.visitUnpivotClause(this); } else { return visitor.visitChildren(this); } } } export class UnpivotNullClauseContext extends ParserRuleContext { public KW_NULLS(): TerminalNode { return this.getToken(SparkSqlParser.KW_NULLS, 0); } public KW_INCLUDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INCLUDE, 0); } public KW_EXCLUDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXCLUDE, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotNullClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotNullClause) { listener.enterUnpivotNullClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotNullClause) { listener.exitUnpivotNullClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotNullClause) { return visitor.visitUnpivotNullClause(this); } else { return visitor.visitChildren(this); } } } export class UnpivotOperatorContext extends ParserRuleContext { public unpivotSingleValueColumnClause(): UnpivotSingleValueColumnClauseContext | undefined { return this.tryGetRuleContext(0, UnpivotSingleValueColumnClauseContext); } public unpivotMultiValueColumnClause(): UnpivotMultiValueColumnClauseContext | undefined { return this.tryGetRuleContext(0, UnpivotMultiValueColumnClauseContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotOperator; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotOperator) { listener.enterUnpivotOperator(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotOperator) { listener.exitUnpivotOperator(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotOperator) { return visitor.visitUnpivotOperator(this); } else { return visitor.visitChildren(this); } } } export class UnpivotSingleValueColumnClauseContext extends ParserRuleContext { public _unpivotColumnAndAlias!: UnpivotColumnAndAliasContext; public _unpivotColumns: UnpivotColumnAndAliasContext[] = []; public unpivotValueColumn(): UnpivotValueColumnContext { return this.getRuleContext(0, UnpivotValueColumnContext); } public KW_FOR(): TerminalNode { return this.getToken(SparkSqlParser.KW_FOR, 0); } public unpivotNameColumn(): UnpivotNameColumnContext { return this.getRuleContext(0, UnpivotNameColumnContext); } public KW_IN(): TerminalNode { return this.getToken(SparkSqlParser.KW_IN, 0); } public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public unpivotColumnAndAlias(): UnpivotColumnAndAliasContext[]; public unpivotColumnAndAlias(i: number): UnpivotColumnAndAliasContext; public unpivotColumnAndAlias(i?: number): UnpivotColumnAndAliasContext | UnpivotColumnAndAliasContext[] { if (i === undefined) { return this.getRuleContexts(UnpivotColumnAndAliasContext); } else { return this.getRuleContext(i, UnpivotColumnAndAliasContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotSingleValueColumnClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotSingleValueColumnClause) { listener.enterUnpivotSingleValueColumnClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotSingleValueColumnClause) { listener.exitUnpivotSingleValueColumnClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotSingleValueColumnClause) { return visitor.visitUnpivotSingleValueColumnClause(this); } else { return visitor.visitChildren(this); } } } export class UnpivotMultiValueColumnClauseContext extends ParserRuleContext { public _unpivotValueColumn!: UnpivotValueColumnContext; public _unpivotValueColumns: UnpivotValueColumnContext[] = []; public _unpivotColumnSet!: UnpivotColumnSetContext; public _unpivotColumnSets: UnpivotColumnSetContext[] = []; public LEFT_PAREN(): TerminalNode[]; public LEFT_PAREN(i: number): TerminalNode; public LEFT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.LEFT_PAREN); } else { return this.getToken(SparkSqlParser.LEFT_PAREN, i); } } public RIGHT_PAREN(): TerminalNode[]; public RIGHT_PAREN(i: number): TerminalNode; public RIGHT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.RIGHT_PAREN); } else { return this.getToken(SparkSqlParser.RIGHT_PAREN, i); } } public KW_FOR(): TerminalNode { return this.getToken(SparkSqlParser.KW_FOR, 0); } public unpivotNameColumn(): UnpivotNameColumnContext { return this.getRuleContext(0, UnpivotNameColumnContext); } public KW_IN(): TerminalNode { return this.getToken(SparkSqlParser.KW_IN, 0); } public unpivotValueColumn(): UnpivotValueColumnContext[]; public unpivotValueColumn(i: number): UnpivotValueColumnContext; public unpivotValueColumn(i?: number): UnpivotValueColumnContext | UnpivotValueColumnContext[] { if (i === undefined) { return this.getRuleContexts(UnpivotValueColumnContext); } else { return this.getRuleContext(i, UnpivotValueColumnContext); } } public unpivotColumnSet(): UnpivotColumnSetContext[]; public unpivotColumnSet(i: number): UnpivotColumnSetContext; public unpivotColumnSet(i?: number): UnpivotColumnSetContext | UnpivotColumnSetContext[] { if (i === undefined) { return this.getRuleContexts(UnpivotColumnSetContext); } else { return this.getRuleContext(i, UnpivotColumnSetContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotMultiValueColumnClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotMultiValueColumnClause) { listener.enterUnpivotMultiValueColumnClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotMultiValueColumnClause) { listener.exitUnpivotMultiValueColumnClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotMultiValueColumnClause) { return visitor.visitUnpivotMultiValueColumnClause(this); } else { return visitor.visitChildren(this); } } } export class UnpivotColumnSetContext extends ParserRuleContext { public _unpivotColumn!: UnpivotColumnContext; public _unpivotColumns: UnpivotColumnContext[] = []; public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public unpivotColumn(): UnpivotColumnContext[]; public unpivotColumn(i: number): UnpivotColumnContext; public unpivotColumn(i?: number): UnpivotColumnContext | UnpivotColumnContext[] { if (i === undefined) { return this.getRuleContexts(UnpivotColumnContext); } else { return this.getRuleContext(i, UnpivotColumnContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } public unpivotAlias(): UnpivotAliasContext | undefined { return this.tryGetRuleContext(0, UnpivotAliasContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotColumnSet; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotColumnSet) { listener.enterUnpivotColumnSet(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotColumnSet) { listener.exitUnpivotColumnSet(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotColumnSet) { return visitor.visitUnpivotColumnSet(this); } else { return visitor.visitChildren(this); } } } export class UnpivotValueColumnContext extends ParserRuleContext { public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotValueColumn; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotValueColumn) { listener.enterUnpivotValueColumn(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotValueColumn) { listener.exitUnpivotValueColumn(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotValueColumn) { return visitor.visitUnpivotValueColumn(this); } else { return visitor.visitChildren(this); } } } export class UnpivotNameColumnContext extends ParserRuleContext { public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotNameColumn; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotNameColumn) { listener.enterUnpivotNameColumn(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotNameColumn) { listener.exitUnpivotNameColumn(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotNameColumn) { return visitor.visitUnpivotNameColumn(this); } else { return visitor.visitChildren(this); } } } export class UnpivotColumnAndAliasContext extends ParserRuleContext { public unpivotColumn(): UnpivotColumnContext { return this.getRuleContext(0, UnpivotColumnContext); } public unpivotAlias(): UnpivotAliasContext | undefined { return this.tryGetRuleContext(0, UnpivotAliasContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotColumnAndAlias; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotColumnAndAlias) { listener.enterUnpivotColumnAndAlias(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotColumnAndAlias) { listener.exitUnpivotColumnAndAlias(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotColumnAndAlias) { return visitor.visitUnpivotColumnAndAlias(this); } else { return visitor.visitChildren(this); } } } export class UnpivotColumnContext extends ParserRuleContext { public multipartIdentifier(): MultipartIdentifierContext { return this.getRuleContext(0, MultipartIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotColumn; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotColumn) { listener.enterUnpivotColumn(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotColumn) { listener.exitUnpivotColumn(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotColumn) { return visitor.visitUnpivotColumn(this); } else { return visitor.visitChildren(this); } } } export class UnpivotAliasContext extends ParserRuleContext { public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unpivotAlias; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnpivotAlias) { listener.enterUnpivotAlias(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnpivotAlias) { listener.exitUnpivotAlias(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnpivotAlias) { return visitor.visitUnpivotAlias(this); } else { return visitor.visitChildren(this); } } } export class IfNotExistsContext extends ParserRuleContext { public KW_IF(): TerminalNode { return this.getToken(SparkSqlParser.KW_IF, 0); } public KW_NOT(): TerminalNode { return this.getToken(SparkSqlParser.KW_NOT, 0); } public KW_EXISTS(): TerminalNode { return this.getToken(SparkSqlParser.KW_EXISTS, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_ifNotExists; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterIfNotExists) { listener.enterIfNotExists(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitIfNotExists) { listener.exitIfNotExists(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitIfNotExists) { return visitor.visitIfNotExists(this); } else { return visitor.visitChildren(this); } } } export class IfExistsContext extends ParserRuleContext { public KW_IF(): TerminalNode { return this.getToken(SparkSqlParser.KW_IF, 0); } public KW_EXISTS(): TerminalNode { return this.getToken(SparkSqlParser.KW_EXISTS, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_ifExists; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterIfExists) { listener.enterIfExists(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitIfExists) { listener.exitIfExists(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitIfExists) { return visitor.visitIfExists(this); } else { return visitor.visitChildren(this); } } } export class LateralViewContext extends ParserRuleContext { public _identifier!: IdentifierContext; public _colName: IdentifierContext[] = []; public KW_LATERAL(): TerminalNode { return this.getToken(SparkSqlParser.KW_LATERAL, 0); } public KW_VIEW(): TerminalNode { return this.getToken(SparkSqlParser.KW_VIEW, 0); } public viewName(): ViewNameContext { return this.getRuleContext(0, ViewNameContext); } public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public tableAlias(): TableAliasContext { return this.getRuleContext(0, TableAliasContext); } public KW_OUTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OUTER, 0); } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public identifier(): IdentifierContext[]; public identifier(i: number): IdentifierContext; public identifier(i?: number): IdentifierContext | IdentifierContext[] { if (i === undefined) { return this.getRuleContexts(IdentifierContext); } else { return this.getRuleContext(i, IdentifierContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_lateralView; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterLateralView) { listener.enterLateralView(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitLateralView) { listener.exitLateralView(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitLateralView) { return visitor.visitLateralView(this); } else { return visitor.visitChildren(this); } } } export class SetQuantifierContext extends ParserRuleContext { public KW_DISTINCT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DISTINCT, 0); } public KW_ALL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALL, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_setQuantifier; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterSetQuantifier) { listener.enterSetQuantifier(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitSetQuantifier) { listener.exitSetQuantifier(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitSetQuantifier) { return visitor.visitSetQuantifier(this); } else { return visitor.visitChildren(this); } } } export class RelationContext extends ParserRuleContext { public relationPrimary(): RelationPrimaryContext | undefined { return this.tryGetRuleContext(0, RelationPrimaryContext); } public KW_LATERAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LATERAL, 0); } public relationExtension(): RelationExtensionContext[]; public relationExtension(i: number): RelationExtensionContext; public relationExtension(i?: number): RelationExtensionContext | RelationExtensionContext[] { if (i === undefined) { return this.getRuleContexts(RelationExtensionContext); } else { return this.getRuleContext(i, RelationExtensionContext); } } public tableName(): TableNameContext | undefined { return this.tryGetRuleContext(0, TableNameContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_relation; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterRelation) { listener.enterRelation(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitRelation) { listener.exitRelation(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitRelation) { return visitor.visitRelation(this); } else { return visitor.visitChildren(this); } } } export class RelationExtensionContext extends ParserRuleContext { public joinRelation(): JoinRelationContext | undefined { return this.tryGetRuleContext(0, JoinRelationContext); } public pivotClause(): PivotClauseContext | undefined { return this.tryGetRuleContext(0, PivotClauseContext); } public unpivotClause(): UnpivotClauseContext | undefined { return this.tryGetRuleContext(0, UnpivotClauseContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_relationExtension; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterRelationExtension) { listener.enterRelationExtension(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitRelationExtension) { listener.exitRelationExtension(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitRelationExtension) { return visitor.visitRelationExtension(this); } else { return visitor.visitChildren(this); } } } export class JoinRelationContext extends ParserRuleContext { public _right!: RelationPrimaryContext; public KW_JOIN(): TerminalNode { return this.getToken(SparkSqlParser.KW_JOIN, 0); } public relationPrimary(): RelationPrimaryContext { return this.getRuleContext(0, RelationPrimaryContext); } public joinType(): JoinTypeContext | undefined { return this.tryGetRuleContext(0, JoinTypeContext); } public KW_LATERAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LATERAL, 0); } public joinCriteria(): JoinCriteriaContext | undefined { return this.tryGetRuleContext(0, JoinCriteriaContext); } public KW_NATURAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NATURAL, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_joinRelation; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterJoinRelation) { listener.enterJoinRelation(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitJoinRelation) { listener.exitJoinRelation(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitJoinRelation) { return visitor.visitJoinRelation(this); } else { return visitor.visitChildren(this); } } } export class JoinTypeContext extends ParserRuleContext { public KW_INNER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INNER, 0); } public KW_CROSS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CROSS, 0); } public KW_LEFT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LEFT, 0); } public KW_OUTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OUTER, 0); } public KW_SEMI(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SEMI, 0); } public KW_RIGHT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RIGHT, 0); } public KW_FULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FULL, 0); } public KW_ANTI(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANTI, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_joinType; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterJoinType) { listener.enterJoinType(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitJoinType) { listener.exitJoinType(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitJoinType) { return visitor.visitJoinType(this); } else { return visitor.visitChildren(this); } } } export class JoinCriteriaContext extends ParserRuleContext { public KW_ON(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ON, 0); } public booleanExpression(): BooleanExpressionContext | undefined { return this.tryGetRuleContext(0, BooleanExpressionContext); } public KW_USING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_USING, 0); } public identifierList(): IdentifierListContext | undefined { return this.tryGetRuleContext(0, IdentifierListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_joinCriteria; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterJoinCriteria) { listener.enterJoinCriteria(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitJoinCriteria) { listener.exitJoinCriteria(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitJoinCriteria) { return visitor.visitJoinCriteria(this); } else { return visitor.visitChildren(this); } } } export class SampleContext extends ParserRuleContext { public _seed!: Token; public KW_TABLESAMPLE(): TerminalNode { return this.getToken(SparkSqlParser.KW_TABLESAMPLE, 0); } public LEFT_PAREN(): TerminalNode[]; public LEFT_PAREN(i: number): TerminalNode; public LEFT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.LEFT_PAREN); } else { return this.getToken(SparkSqlParser.LEFT_PAREN, i); } } public RIGHT_PAREN(): TerminalNode[]; public RIGHT_PAREN(i: number): TerminalNode; public RIGHT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.RIGHT_PAREN); } else { return this.getToken(SparkSqlParser.RIGHT_PAREN, i); } } public sampleMethod(): SampleMethodContext | undefined { return this.tryGetRuleContext(0, SampleMethodContext); } public KW_REPEATABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPEATABLE, 0); } public INTEGER_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.INTEGER_VALUE, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_sample; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterSample) { listener.enterSample(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitSample) { listener.exitSample(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitSample) { return visitor.visitSample(this); } else { return visitor.visitChildren(this); } } } export class SampleMethodContext extends ParserRuleContext { public _negativeSign!: Token; public _percentage!: Token; public _sampleType!: Token; public _numerator!: Token; public _denominator!: Token; public _bytes!: ExpressionContext; public KW_PERCENTLIT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PERCENTLIT, 0); } public INTEGER_VALUE(): TerminalNode[]; public INTEGER_VALUE(i: number): TerminalNode; public INTEGER_VALUE(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.INTEGER_VALUE); } else { return this.getToken(SparkSqlParser.INTEGER_VALUE, i); } } public DECIMAL_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.DECIMAL_VALUE, 0); } public MINUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.MINUS, 0); } public expression(): ExpressionContext | undefined { return this.tryGetRuleContext(0, ExpressionContext); } public KW_ROWS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROWS, 0); } public KW_OUT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OUT, 0); } public KW_OF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OF, 0); } public KW_BUCKET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BUCKET, 0); } public KW_ON(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ON, 0); } public identifier(): IdentifierContext | undefined { return this.tryGetRuleContext(0, IdentifierContext); } public qualifiedName(): QualifiedNameContext | undefined { return this.tryGetRuleContext(0, QualifiedNameContext); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_sampleMethod; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterSampleMethod) { listener.enterSampleMethod(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitSampleMethod) { listener.exitSampleMethod(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitSampleMethod) { return visitor.visitSampleMethod(this); } else { return visitor.visitChildren(this); } } } export class IdentifierListContext extends ParserRuleContext { public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public identifierSeq(): IdentifierSeqContext { return this.getRuleContext(0, IdentifierSeqContext); } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_identifierList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterIdentifierList) { listener.enterIdentifierList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitIdentifierList) { listener.exitIdentifierList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitIdentifierList) { return visitor.visitIdentifierList(this); } else { return visitor.visitChildren(this); } } } export class IdentifierSeqContext extends ParserRuleContext { public _errorCapturingIdentifier!: ErrorCapturingIdentifierContext; public _ident: ErrorCapturingIdentifierContext[] = []; public errorCapturingIdentifier(): ErrorCapturingIdentifierContext[]; public errorCapturingIdentifier(i: number): ErrorCapturingIdentifierContext; public errorCapturingIdentifier(i?: number): ErrorCapturingIdentifierContext | ErrorCapturingIdentifierContext[] { if (i === undefined) { return this.getRuleContexts(ErrorCapturingIdentifierContext); } else { return this.getRuleContext(i, ErrorCapturingIdentifierContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_identifierSeq; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterIdentifierSeq) { listener.enterIdentifierSeq(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitIdentifierSeq) { listener.exitIdentifierSeq(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitIdentifierSeq) { return visitor.visitIdentifierSeq(this); } else { return visitor.visitChildren(this); } } } export class OrderedIdentifierListContext extends ParserRuleContext { public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public orderedIdentifier(): OrderedIdentifierContext[]; public orderedIdentifier(i: number): OrderedIdentifierContext; public orderedIdentifier(i?: number): OrderedIdentifierContext | OrderedIdentifierContext[] { if (i === undefined) { return this.getRuleContexts(OrderedIdentifierContext); } else { return this.getRuleContext(i, OrderedIdentifierContext); } } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_orderedIdentifierList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterOrderedIdentifierList) { listener.enterOrderedIdentifierList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitOrderedIdentifierList) { listener.exitOrderedIdentifierList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitOrderedIdentifierList) { return visitor.visitOrderedIdentifierList(this); } else { return visitor.visitChildren(this); } } } export class OrderedIdentifierContext extends ParserRuleContext { public _ident!: ErrorCapturingIdentifierContext; public _ordering!: Token; public errorCapturingIdentifier(): ErrorCapturingIdentifierContext { return this.getRuleContext(0, ErrorCapturingIdentifierContext); } public KW_ASC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ASC, 0); } public KW_DESC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DESC, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_orderedIdentifier; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterOrderedIdentifier) { listener.enterOrderedIdentifier(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitOrderedIdentifier) { listener.exitOrderedIdentifier(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitOrderedIdentifier) { return visitor.visitOrderedIdentifier(this); } else { return visitor.visitChildren(this); } } } export class IdentifierCommentListContext extends ParserRuleContext { public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public identifierComment(): IdentifierCommentContext[]; public identifierComment(i: number): IdentifierCommentContext; public identifierComment(i?: number): IdentifierCommentContext | IdentifierCommentContext[] { if (i === undefined) { return this.getRuleContexts(IdentifierCommentContext); } else { return this.getRuleContext(i, IdentifierCommentContext); } } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_identifierCommentList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterIdentifierCommentList) { listener.enterIdentifierCommentList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitIdentifierCommentList) { listener.exitIdentifierCommentList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitIdentifierCommentList) { return visitor.visitIdentifierCommentList(this); } else { return visitor.visitChildren(this); } } } export class IdentifierCommentContext extends ParserRuleContext { public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } public commentSpec(): CommentSpecContext | undefined { return this.tryGetRuleContext(0, CommentSpecContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_identifierComment; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterIdentifierComment) { listener.enterIdentifierComment(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitIdentifierComment) { listener.exitIdentifierComment(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitIdentifierComment) { return visitor.visitIdentifierComment(this); } else { return visitor.visitChildren(this); } } } export class RelationPrimaryContext extends ParserRuleContext { public identifierReference(): IdentifierReferenceContext | undefined { return this.tryGetRuleContext(0, IdentifierReferenceContext); } public tableAlias(): TableAliasContext | undefined { return this.tryGetRuleContext(0, TableAliasContext); } public temporalClause(): TemporalClauseContext | undefined { return this.tryGetRuleContext(0, TemporalClauseContext); } public sample(): SampleContext | undefined { return this.tryGetRuleContext(0, SampleContext); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public query(): QueryContext | undefined { return this.tryGetRuleContext(0, QueryContext); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public relation(): RelationContext | undefined { return this.tryGetRuleContext(0, RelationContext); } public inlineTable(): InlineTableContext | undefined { return this.tryGetRuleContext(0, InlineTableContext); } public functionTable(): FunctionTableContext | undefined { return this.tryGetRuleContext(0, FunctionTableContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_relationPrimary; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterRelationPrimary) { listener.enterRelationPrimary(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitRelationPrimary) { listener.exitRelationPrimary(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitRelationPrimary) { return visitor.visitRelationPrimary(this); } else { return visitor.visitChildren(this); } } } export class InlineTableContext extends ParserRuleContext { public KW_VALUES(): TerminalNode { return this.getToken(SparkSqlParser.KW_VALUES, 0); } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public tableAlias(): TableAliasContext { return this.getRuleContext(0, TableAliasContext); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_inlineTable; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterInlineTable) { listener.enterInlineTable(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitInlineTable) { listener.exitInlineTable(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitInlineTable) { return visitor.visitInlineTable(this); } else { return visitor.visitChildren(this); } } } export class FunctionTableSubqueryArgumentContext extends ParserRuleContext { public KW_TABLE(): TerminalNode { return this.getToken(SparkSqlParser.KW_TABLE, 0); } public tableName(): TableNameContext | undefined { return this.tryGetRuleContext(0, TableNameContext); } public tableArgumentPartitioning(): TableArgumentPartitioningContext | undefined { return this.tryGetRuleContext(0, TableArgumentPartitioningContext); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public query(): QueryContext | undefined { return this.tryGetRuleContext(0, QueryContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_functionTableSubqueryArgument; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFunctionTableSubqueryArgument) { listener.enterFunctionTableSubqueryArgument(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFunctionTableSubqueryArgument) { listener.exitFunctionTableSubqueryArgument(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFunctionTableSubqueryArgument) { return visitor.visitFunctionTableSubqueryArgument(this); } else { return visitor.visitChildren(this); } } } export class TableArgumentPartitioningContext extends ParserRuleContext { public _expression!: ExpressionContext; public _partition: ExpressionContext[] = []; public KW_BY(): TerminalNode[]; public KW_BY(i: number): TerminalNode; public KW_BY(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_BY); } else { return this.getToken(SparkSqlParser.KW_BY, i); } } public KW_WITH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WITH, 0); } public KW_SINGLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SINGLE, 0); } public KW_PARTITION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PARTITION, 0); } public KW_ORDER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ORDER, 0); } public KW_SORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SORT, 0); } public KW_DISTRIBUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DISTRIBUTE, 0); } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public sortItem(): SortItemContext[]; public sortItem(i: number): SortItemContext; public sortItem(i?: number): SortItemContext | SortItemContext[] { if (i === undefined) { return this.getRuleContexts(SortItemContext); } else { return this.getRuleContext(i, SortItemContext); } } public LEFT_PAREN(): TerminalNode[]; public LEFT_PAREN(i: number): TerminalNode; public LEFT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.LEFT_PAREN); } else { return this.getToken(SparkSqlParser.LEFT_PAREN, i); } } public RIGHT_PAREN(): TerminalNode[]; public RIGHT_PAREN(i: number): TerminalNode; public RIGHT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.RIGHT_PAREN); } else { return this.getToken(SparkSqlParser.RIGHT_PAREN, i); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_tableArgumentPartitioning; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTableArgumentPartitioning) { listener.enterTableArgumentPartitioning(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTableArgumentPartitioning) { listener.exitTableArgumentPartitioning(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTableArgumentPartitioning) { return visitor.visitTableArgumentPartitioning(this); } else { return visitor.visitChildren(this); } } } export class FunctionTableNamedArgumentExpressionContext extends ParserRuleContext { public _key!: IdentifierContext; public _table!: FunctionTableSubqueryArgumentContext; public FAT_ARROW(): TerminalNode { return this.getToken(SparkSqlParser.FAT_ARROW, 0); } public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } public functionTableSubqueryArgument(): FunctionTableSubqueryArgumentContext { return this.getRuleContext(0, FunctionTableSubqueryArgumentContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_functionTableNamedArgumentExpression; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFunctionTableNamedArgumentExpression) { listener.enterFunctionTableNamedArgumentExpression(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFunctionTableNamedArgumentExpression) { listener.exitFunctionTableNamedArgumentExpression(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFunctionTableNamedArgumentExpression) { return visitor.visitFunctionTableNamedArgumentExpression(this); } else { return visitor.visitChildren(this); } } } export class FunctionTableReferenceArgumentContext extends ParserRuleContext { public functionTableSubqueryArgument(): FunctionTableSubqueryArgumentContext | undefined { return this.tryGetRuleContext(0, FunctionTableSubqueryArgumentContext); } public functionTableNamedArgumentExpression(): FunctionTableNamedArgumentExpressionContext | undefined { return this.tryGetRuleContext(0, FunctionTableNamedArgumentExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_functionTableReferenceArgument; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFunctionTableReferenceArgument) { listener.enterFunctionTableReferenceArgument(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFunctionTableReferenceArgument) { listener.exitFunctionTableReferenceArgument(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFunctionTableReferenceArgument) { return visitor.visitFunctionTableReferenceArgument(this); } else { return visitor.visitChildren(this); } } } export class FunctionTableArgumentContext extends ParserRuleContext { public functionTableReferenceArgument(): FunctionTableReferenceArgumentContext | undefined { return this.tryGetRuleContext(0, FunctionTableReferenceArgumentContext); } public functionArgument(): FunctionArgumentContext | undefined { return this.tryGetRuleContext(0, FunctionArgumentContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_functionTableArgument; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFunctionTableArgument) { listener.enterFunctionTableArgument(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFunctionTableArgument) { listener.exitFunctionTableArgument(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFunctionTableArgument) { return visitor.visitFunctionTableArgument(this); } else { return visitor.visitChildren(this); } } } export class FunctionTableContext extends ParserRuleContext { public functionName(): FunctionNameContext { return this.getRuleContext(0, FunctionNameContext); } public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public tableAlias(): TableAliasContext { return this.getRuleContext(0, TableAliasContext); } public functionTableArgument(): FunctionTableArgumentContext[]; public functionTableArgument(i: number): FunctionTableArgumentContext; public functionTableArgument(i?: number): FunctionTableArgumentContext | FunctionTableArgumentContext[] { if (i === undefined) { return this.getRuleContexts(FunctionTableArgumentContext); } else { return this.getRuleContext(i, FunctionTableArgumentContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_functionTable; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFunctionTable) { listener.enterFunctionTable(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFunctionTable) { listener.exitFunctionTable(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFunctionTable) { return visitor.visitFunctionTable(this); } else { return visitor.visitChildren(this); } } } export class TableAliasContext extends ParserRuleContext { public strictIdentifier(): StrictIdentifierContext | undefined { return this.tryGetRuleContext(0, StrictIdentifierContext); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public identifierList(): IdentifierListContext | undefined { return this.tryGetRuleContext(0, IdentifierListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_tableAlias; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTableAlias) { listener.enterTableAlias(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTableAlias) { listener.exitTableAlias(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTableAlias) { return visitor.visitTableAlias(this); } else { return visitor.visitChildren(this); } } } export class RowFormatContext extends ParserRuleContext { public _name!: StringLitContext; public _props!: PropertyListContext; public _fieldsTerminatedBy!: StringLitContext; public _escapedBy!: StringLitContext; public _collectionItemsTerminatedBy!: StringLitContext; public _keysTerminatedBy!: StringLitContext; public _linesSeparatedBy!: StringLitContext; public _nullDefinedAs!: StringLitContext; public KW_ROW(): TerminalNode { return this.getToken(SparkSqlParser.KW_ROW, 0); } public KW_FORMAT(): TerminalNode { return this.getToken(SparkSqlParser.KW_FORMAT, 0); } public KW_SERDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SERDE, 0); } public stringLit(): StringLitContext[]; public stringLit(i: number): StringLitContext; public stringLit(i?: number): StringLitContext | StringLitContext[] { if (i === undefined) { return this.getRuleContexts(StringLitContext); } else { return this.getRuleContext(i, StringLitContext); } } public KW_WITH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WITH, 0); } public KW_SERDEPROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SERDEPROPERTIES, 0); } public propertyList(): PropertyListContext | undefined { return this.tryGetRuleContext(0, PropertyListContext); } public KW_DELIMITED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DELIMITED, 0); } public KW_FIELDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FIELDS, 0); } public KW_TERMINATED(): TerminalNode[]; public KW_TERMINATED(i: number): TerminalNode; public KW_TERMINATED(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_TERMINATED); } else { return this.getToken(SparkSqlParser.KW_TERMINATED, i); } } public KW_BY(): TerminalNode[]; public KW_BY(i: number): TerminalNode; public KW_BY(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_BY); } else { return this.getToken(SparkSqlParser.KW_BY, i); } } public KW_COLLECTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COLLECTION, 0); } public KW_ITEMS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ITEMS, 0); } public KW_MAP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MAP, 0); } public KW_KEYS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_KEYS, 0); } public KW_LINES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LINES, 0); } public KW_NULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULL, 0); } public KW_DEFINED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEFINED, 0); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public KW_ESCAPED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ESCAPED, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_rowFormat; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterRowFormat) { listener.enterRowFormat(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitRowFormat) { listener.exitRowFormat(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitRowFormat) { return visitor.visitRowFormat(this); } else { return visitor.visitChildren(this); } } } export class MultipartIdentifierListContext extends ParserRuleContext { public multipartIdentifier(): MultipartIdentifierContext[]; public multipartIdentifier(i: number): MultipartIdentifierContext; public multipartIdentifier(i?: number): MultipartIdentifierContext | MultipartIdentifierContext[] { if (i === undefined) { return this.getRuleContexts(MultipartIdentifierContext); } else { return this.getRuleContext(i, MultipartIdentifierContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_multipartIdentifierList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterMultipartIdentifierList) { listener.enterMultipartIdentifierList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitMultipartIdentifierList) { listener.exitMultipartIdentifierList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitMultipartIdentifierList) { return visitor.visitMultipartIdentifierList(this); } else { return visitor.visitChildren(this); } } } export class MultipartIdentifierContext extends ParserRuleContext { public _errorCapturingIdentifier!: ErrorCapturingIdentifierContext; public _parts: ErrorCapturingIdentifierContext[] = []; public errorCapturingIdentifier(): ErrorCapturingIdentifierContext[]; public errorCapturingIdentifier(i: number): ErrorCapturingIdentifierContext; public errorCapturingIdentifier(i?: number): ErrorCapturingIdentifierContext | ErrorCapturingIdentifierContext[] { if (i === undefined) { return this.getRuleContexts(ErrorCapturingIdentifierContext); } else { return this.getRuleContext(i, ErrorCapturingIdentifierContext); } } public DOT(): TerminalNode[]; public DOT(i: number): TerminalNode; public DOT(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.DOT); } else { return this.getToken(SparkSqlParser.DOT, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_multipartIdentifier; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterMultipartIdentifier) { listener.enterMultipartIdentifier(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitMultipartIdentifier) { listener.exitMultipartIdentifier(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitMultipartIdentifier) { return visitor.visitMultipartIdentifier(this); } else { return visitor.visitChildren(this); } } } export class MultipartIdentifierPropertyListContext extends ParserRuleContext { public multipartIdentifierProperty(): MultipartIdentifierPropertyContext[]; public multipartIdentifierProperty(i: number): MultipartIdentifierPropertyContext; public multipartIdentifierProperty(i?: number): MultipartIdentifierPropertyContext | MultipartIdentifierPropertyContext[] { if (i === undefined) { return this.getRuleContexts(MultipartIdentifierPropertyContext); } else { return this.getRuleContext(i, MultipartIdentifierPropertyContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_multipartIdentifierPropertyList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterMultipartIdentifierPropertyList) { listener.enterMultipartIdentifierPropertyList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitMultipartIdentifierPropertyList) { listener.exitMultipartIdentifierPropertyList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitMultipartIdentifierPropertyList) { return visitor.visitMultipartIdentifierPropertyList(this); } else { return visitor.visitChildren(this); } } } export class MultipartIdentifierPropertyContext extends ParserRuleContext { public _options!: PropertyListContext; public multipartIdentifier(): MultipartIdentifierContext { return this.getRuleContext(0, MultipartIdentifierContext); } public KW_OPTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OPTIONS, 0); } public propertyList(): PropertyListContext | undefined { return this.tryGetRuleContext(0, PropertyListContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_multipartIdentifierProperty; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterMultipartIdentifierProperty) { listener.enterMultipartIdentifierProperty(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitMultipartIdentifierProperty) { listener.exitMultipartIdentifierProperty(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitMultipartIdentifierProperty) { return visitor.visitMultipartIdentifierProperty(this); } else { return visitor.visitChildren(this); } } } export class TableIdentifierContext extends ParserRuleContext { public _db!: ErrorCapturingIdentifierContext; public _table!: ErrorCapturingIdentifierContext; public errorCapturingIdentifier(): ErrorCapturingIdentifierContext[]; public errorCapturingIdentifier(i: number): ErrorCapturingIdentifierContext; public errorCapturingIdentifier(i?: number): ErrorCapturingIdentifierContext | ErrorCapturingIdentifierContext[] { if (i === undefined) { return this.getRuleContexts(ErrorCapturingIdentifierContext); } else { return this.getRuleContext(i, ErrorCapturingIdentifierContext); } } public DOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.DOT, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_tableIdentifier; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTableIdentifier) { listener.enterTableIdentifier(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTableIdentifier) { listener.exitTableIdentifier(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTableIdentifier) { return visitor.visitTableIdentifier(this); } else { return visitor.visitChildren(this); } } } export class ViewIdentifierContext extends ParserRuleContext { public _db!: ErrorCapturingIdentifierContext; public _view!: ErrorCapturingIdentifierContext; public errorCapturingIdentifier(): ErrorCapturingIdentifierContext[]; public errorCapturingIdentifier(i: number): ErrorCapturingIdentifierContext; public errorCapturingIdentifier(i?: number): ErrorCapturingIdentifierContext | ErrorCapturingIdentifierContext[] { if (i === undefined) { return this.getRuleContexts(ErrorCapturingIdentifierContext); } else { return this.getRuleContext(i, ErrorCapturingIdentifierContext); } } public DOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.DOT, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_viewIdentifier; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterViewIdentifier) { listener.enterViewIdentifier(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitViewIdentifier) { listener.exitViewIdentifier(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitViewIdentifier) { return visitor.visitViewIdentifier(this); } else { return visitor.visitChildren(this); } } } export class NamedExpressionContext extends ParserRuleContext { public _name!: ErrorCapturingIdentifierContext; public expression(): ExpressionContext { return this.getRuleContext(0, ExpressionContext); } public identifierList(): IdentifierListContext | undefined { return this.tryGetRuleContext(0, IdentifierListContext); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public errorCapturingIdentifier(): ErrorCapturingIdentifierContext | undefined { return this.tryGetRuleContext(0, ErrorCapturingIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_namedExpression; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNamedExpression) { listener.enterNamedExpression(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNamedExpression) { listener.exitNamedExpression(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNamedExpression) { return visitor.visitNamedExpression(this); } else { return visitor.visitChildren(this); } } } export class NamedExpressionSeqContext extends ParserRuleContext { public namedExpression(): NamedExpressionContext[]; public namedExpression(i: number): NamedExpressionContext; public namedExpression(i?: number): NamedExpressionContext | NamedExpressionContext[] { if (i === undefined) { return this.getRuleContexts(NamedExpressionContext); } else { return this.getRuleContext(i, NamedExpressionContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_namedExpressionSeq; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNamedExpressionSeq) { listener.enterNamedExpressionSeq(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNamedExpressionSeq) { listener.exitNamedExpressionSeq(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNamedExpressionSeq) { return visitor.visitNamedExpressionSeq(this); } else { return visitor.visitChildren(this); } } } export class PartitionFieldListContext extends ParserRuleContext { public _partitionField!: PartitionFieldContext; public _fields: PartitionFieldContext[] = []; public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } public partitionField(): PartitionFieldContext[]; public partitionField(i: number): PartitionFieldContext; public partitionField(i?: number): PartitionFieldContext | PartitionFieldContext[] { if (i === undefined) { return this.getRuleContexts(PartitionFieldContext); } else { return this.getRuleContext(i, PartitionFieldContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_partitionFieldList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPartitionFieldList) { listener.enterPartitionFieldList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPartitionFieldList) { listener.exitPartitionFieldList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPartitionFieldList) { return visitor.visitPartitionFieldList(this); } else { return visitor.visitChildren(this); } } } export class PartitionFieldContext extends ParserRuleContext { public transform(): TransformContext | undefined { return this.tryGetRuleContext(0, TransformContext); } public colType(): ColTypeContext | undefined { return this.tryGetRuleContext(0, ColTypeContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_partitionField; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPartitionField) { listener.enterPartitionField(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPartitionField) { listener.exitPartitionField(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPartitionField) { return visitor.visitPartitionField(this); } else { return visitor.visitChildren(this); } } } export class TransformContext extends ParserRuleContext { public _transformName!: IdentifierContext; public qualifiedName(): QualifiedNameContext | undefined { return this.tryGetRuleContext(0, QualifiedNameContext); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public transformArgument(): TransformArgumentContext[]; public transformArgument(i: number): TransformArgumentContext; public transformArgument(i?: number): TransformArgumentContext | TransformArgumentContext[] { if (i === undefined) { return this.getRuleContexts(TransformArgumentContext); } else { return this.getRuleContext(i, TransformArgumentContext); } } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public identifier(): IdentifierContext | undefined { return this.tryGetRuleContext(0, IdentifierContext); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_transform; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTransform) { listener.enterTransform(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTransform) { listener.exitTransform(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTransform) { return visitor.visitTransform(this); } else { return visitor.visitChildren(this); } } } export class TransformArgumentContext extends ParserRuleContext { public qualifiedName(): QualifiedNameContext | undefined { return this.tryGetRuleContext(0, QualifiedNameContext); } public constant(): ConstantContext | undefined { return this.tryGetRuleContext(0, ConstantContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_transformArgument; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterTransformArgument) { listener.enterTransformArgument(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitTransformArgument) { listener.exitTransformArgument(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitTransformArgument) { return visitor.visitTransformArgument(this); } else { return visitor.visitChildren(this); } } } export class ExpressionContext extends ParserRuleContext { public booleanExpression(): BooleanExpressionContext { return this.getRuleContext(0, BooleanExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_expression; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterExpression) { listener.enterExpression(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitExpression) { listener.exitExpression(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitExpression) { return visitor.visitExpression(this); } else { return visitor.visitChildren(this); } } } export class NamedArgumentExpressionContext extends ParserRuleContext { public _key!: IdentifierContext; public _value!: ExpressionContext; public FAT_ARROW(): TerminalNode { return this.getToken(SparkSqlParser.FAT_ARROW, 0); } public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } public expression(): ExpressionContext { return this.getRuleContext(0, ExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_namedArgumentExpression; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNamedArgumentExpression) { listener.enterNamedArgumentExpression(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNamedArgumentExpression) { listener.exitNamedArgumentExpression(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNamedArgumentExpression) { return visitor.visitNamedArgumentExpression(this); } else { return visitor.visitChildren(this); } } } export class FunctionArgumentContext extends ParserRuleContext { public expression(): ExpressionContext | undefined { return this.tryGetRuleContext(0, ExpressionContext); } public namedArgumentExpression(): NamedArgumentExpressionContext | undefined { return this.tryGetRuleContext(0, NamedArgumentExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_functionArgument; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFunctionArgument) { listener.enterFunctionArgument(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFunctionArgument) { listener.exitFunctionArgument(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFunctionArgument) { return visitor.visitFunctionArgument(this); } else { return visitor.visitChildren(this); } } } export class ExpressionSeqContext extends ParserRuleContext { public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_expressionSeq; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterExpressionSeq) { listener.enterExpressionSeq(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitExpressionSeq) { listener.exitExpressionSeq(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitExpressionSeq) { return visitor.visitExpressionSeq(this); } else { return visitor.visitChildren(this); } } } export class BooleanExpressionContext extends ParserRuleContext { public _left!: BooleanExpressionContext; public _operator!: Token; public _right!: BooleanExpressionContext; public booleanExpression(): BooleanExpressionContext[]; public booleanExpression(i: number): BooleanExpressionContext; public booleanExpression(i?: number): BooleanExpressionContext | BooleanExpressionContext[] { if (i === undefined) { return this.getRuleContexts(BooleanExpressionContext); } else { return this.getRuleContext(i, BooleanExpressionContext); } } public KW_NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NOT, 0); } public NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.NOT, 0); } public KW_EXISTS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXISTS, 0); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public query(): QueryContext | undefined { return this.tryGetRuleContext(0, QueryContext); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public valueExpression(): ValueExpressionContext | undefined { return this.tryGetRuleContext(0, ValueExpressionContext); } public predicate(): PredicateContext | undefined { return this.tryGetRuleContext(0, PredicateContext); } public KW_AND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AND, 0); } public KW_OR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OR, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_booleanExpression; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterBooleanExpression) { listener.enterBooleanExpression(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitBooleanExpression) { listener.exitBooleanExpression(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitBooleanExpression) { return visitor.visitBooleanExpression(this); } else { return visitor.visitChildren(this); } } } export class PredicateContext extends ParserRuleContext { public _kind!: Token; public _lower!: ValueExpressionContext; public _upper!: ValueExpressionContext; public _pattern!: ValueExpressionContext; public _quantifier!: Token; public _escapeChar!: StringLitContext; public _right!: ValueExpressionContext; public KW_AND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AND, 0); } public KW_BETWEEN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BETWEEN, 0); } public valueExpression(): ValueExpressionContext[]; public valueExpression(i: number): ValueExpressionContext; public valueExpression(i?: number): ValueExpressionContext | ValueExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ValueExpressionContext); } else { return this.getRuleContext(i, ValueExpressionContext); } } public KW_NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NOT, 0); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public KW_IN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IN, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } public query(): QueryContext | undefined { return this.tryGetRuleContext(0, QueryContext); } public KW_RLIKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RLIKE, 0); } public KW_REGEXP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REGEXP, 0); } public KW_LIKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LIKE, 0); } public KW_ILIKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ILIKE, 0); } public KW_ANY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANY, 0); } public KW_SOME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SOME, 0); } public KW_ALL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALL, 0); } public KW_ESCAPE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ESCAPE, 0); } public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } public KW_IS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IS, 0); } public KW_NULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULL, 0); } public KW_TRUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRUE, 0); } public KW_FALSE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FALSE, 0); } public KW_UNKNOWN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNKNOWN, 0); } public KW_FROM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FROM, 0); } public KW_DISTINCT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DISTINCT, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_predicate; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPredicate) { listener.enterPredicate(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPredicate) { listener.exitPredicate(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPredicate) { return visitor.visitPredicate(this); } else { return visitor.visitChildren(this); } } } export class ValueExpressionContext extends ParserRuleContext { public _left!: ValueExpressionContext; public _operator!: Token; public _right!: ValueExpressionContext; public primaryExpression(): PrimaryExpressionContext | undefined { return this.tryGetRuleContext(0, PrimaryExpressionContext); } public valueExpression(): ValueExpressionContext[]; public valueExpression(i: number): ValueExpressionContext; public valueExpression(i?: number): ValueExpressionContext | ValueExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ValueExpressionContext); } else { return this.getRuleContext(i, ValueExpressionContext); } } public MINUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.MINUS, 0); } public PLUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.PLUS, 0); } public TILDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.TILDE, 0); } public ASTERISK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.ASTERISK, 0); } public SLASH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.SLASH, 0); } public PERCENT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.PERCENT, 0); } public KW_DIV(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIV, 0); } public CONCAT_PIPE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.CONCAT_PIPE, 0); } public AMPERSAND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.AMPERSAND, 0); } public HAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.HAT, 0); } public PIPE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.PIPE, 0); } public comparisonOperator(): ComparisonOperatorContext | undefined { return this.tryGetRuleContext(0, ComparisonOperatorContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_valueExpression; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterValueExpression) { listener.enterValueExpression(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitValueExpression) { listener.exitValueExpression(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitValueExpression) { return visitor.visitValueExpression(this); } else { return visitor.visitChildren(this); } } } export class DatetimeUnitContext extends ParserRuleContext { public KW_YEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_YEAR, 0); } public KW_QUARTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_QUARTER, 0); } public KW_MONTH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MONTH, 0); } public KW_WEEK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WEEK, 0); } public KW_DAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAY, 0); } public KW_DAYOFYEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAYOFYEAR, 0); } public KW_HOUR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_HOUR, 0); } public KW_MINUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MINUTE, 0); } public KW_SECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SECOND, 0); } public KW_MILLISECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MILLISECOND, 0); } public KW_MICROSECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MICROSECOND, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_datetimeUnit; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterDatetimeUnit) { listener.enterDatetimeUnit(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitDatetimeUnit) { listener.exitDatetimeUnit(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitDatetimeUnit) { return visitor.visitDatetimeUnit(this); } else { return visitor.visitChildren(this); } } } export class PrimaryExpressionContext extends ParserRuleContext { public _value!: PrimaryExpressionContext; public _base!: PrimaryExpressionContext; public _name!: Token; public _unit!: DatetimeUnitContext; public _invalidUnit!: StringLitContext; public _unitsAmount!: ValueExpressionContext; public _timestamp!: ValueExpressionContext; public _startTimestamp!: ValueExpressionContext; public _endTimestamp!: ValueExpressionContext; public _elseExpression!: ExpressionContext; public _substr!: ValueExpressionContext; public _str!: ValueExpressionContext; public _where!: BooleanExpressionContext; public _nullsOption!: Token; public _field!: IdentifierContext; public _source!: ValueExpressionContext; public _pos!: ValueExpressionContext; public _len!: ValueExpressionContext; public _trimOption!: Token; public _trimStr!: ValueExpressionContext; public _srcStr!: ValueExpressionContext; public _input!: ValueExpressionContext; public _replace!: ValueExpressionContext; public _position!: ValueExpressionContext; public _length!: ValueExpressionContext; public _percentage!: ValueExpressionContext; public _index!: ValueExpressionContext; public _fieldName!: IdentifierContext; public KW_CURRENT_DATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT_DATE, 0); } public KW_CURRENT_TIMESTAMP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT_TIMESTAMP, 0); } public KW_CURRENT_USER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT_USER, 0); } public KW_USER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_USER, 0); } public KW_SESSION_USER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SESSION_USER, 0); } public LEFT_PAREN(): TerminalNode[]; public LEFT_PAREN(i: number): TerminalNode; public LEFT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.LEFT_PAREN); } else { return this.getToken(SparkSqlParser.LEFT_PAREN, i); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } public RIGHT_PAREN(): TerminalNode[]; public RIGHT_PAREN(i: number): TerminalNode; public RIGHT_PAREN(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.RIGHT_PAREN); } else { return this.getToken(SparkSqlParser.RIGHT_PAREN, i); } } public valueExpression(): ValueExpressionContext[]; public valueExpression(i: number): ValueExpressionContext; public valueExpression(i?: number): ValueExpressionContext | ValueExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ValueExpressionContext); } else { return this.getRuleContext(i, ValueExpressionContext); } } public KW_TIMESTAMPADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMPADD, 0); } public KW_DATEADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATEADD, 0); } public KW_DATE_ADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATE_ADD, 0); } public datetimeUnit(): DatetimeUnitContext | undefined { return this.tryGetRuleContext(0, DatetimeUnitContext); } public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } public KW_TIMESTAMPDIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMPDIFF, 0); } public KW_DATEDIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATEDIFF, 0); } public KW_DATE_DIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATE_DIFF, 0); } public KW_TIMEDIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMEDIFF, 0); } public KW_CASE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CASE, 0); } public KW_END(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_END, 0); } public whenClause(): WhenClauseContext[]; public whenClause(i: number): WhenClauseContext; public whenClause(i?: number): WhenClauseContext | WhenClauseContext[] { if (i === undefined) { return this.getRuleContexts(WhenClauseContext); } else { return this.getRuleContext(i, WhenClauseContext); } } public KW_ELSE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ELSE, 0); } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public dataType(): DataTypeContext | undefined { return this.tryGetRuleContext(0, DataTypeContext); } public KW_CAST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CAST, 0); } public KW_TRY_CAST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRY_CAST, 0); } public KW_STRUCT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STRUCT, 0); } public namedExpression(): NamedExpressionContext[]; public namedExpression(i: number): NamedExpressionContext; public namedExpression(i?: number): NamedExpressionContext | NamedExpressionContext[] { if (i === undefined) { return this.getRuleContexts(NamedExpressionContext); } else { return this.getRuleContext(i, NamedExpressionContext); } } public KW_FIRST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FIRST, 0); } public KW_IGNORE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IGNORE, 0); } public KW_NULLS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULLS, 0); } public KW_ANY_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANY_VALUE, 0); } public KW_LAST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LAST, 0); } public KW_POSITION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_POSITION, 0); } public KW_IN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IN, 0); } public constant(): ConstantContext | undefined { return this.tryGetRuleContext(0, ConstantContext); } public ASTERISK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.ASTERISK, 0); } public qualifiedName(): QualifiedNameContext | undefined { return this.tryGetRuleContext(0, QualifiedNameContext); } public DOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.DOT, 0); } public query(): QueryContext | undefined { return this.tryGetRuleContext(0, QueryContext); } public KW_IDENTIFIER_KW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IDENTIFIER_KW, 0); } public functionName(): FunctionNameContext | undefined { return this.tryGetRuleContext(0, FunctionNameContext); } public functionArgument(): FunctionArgumentContext[]; public functionArgument(i: number): FunctionArgumentContext; public functionArgument(i?: number): FunctionArgumentContext | FunctionArgumentContext[] { if (i === undefined) { return this.getRuleContexts(FunctionArgumentContext); } else { return this.getRuleContext(i, FunctionArgumentContext); } } public KW_FILTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FILTER, 0); } public KW_WHERE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WHERE, 0); } public KW_OVER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVER, 0); } public windowSpec(): WindowSpecContext | undefined { return this.tryGetRuleContext(0, WindowSpecContext); } public booleanExpression(): BooleanExpressionContext | undefined { return this.tryGetRuleContext(0, BooleanExpressionContext); } public KW_RESPECT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RESPECT, 0); } public setQuantifier(): SetQuantifierContext | undefined { return this.tryGetRuleContext(0, SetQuantifierContext); } public identifier(): IdentifierContext[]; public identifier(i: number): IdentifierContext; public identifier(i?: number): IdentifierContext | IdentifierContext[] { if (i === undefined) { return this.getRuleContexts(IdentifierContext); } else { return this.getRuleContext(i, IdentifierContext); } } public ARROW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.ARROW, 0); } public LEFT_BRACKET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_BRACKET, 0); } public RIGHT_BRACKET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_BRACKET, 0); } public primaryExpression(): PrimaryExpressionContext | undefined { return this.tryGetRuleContext(0, PrimaryExpressionContext); } public KW_EXTRACT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXTRACT, 0); } public KW_FROM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FROM, 0); } public KW_SUBSTR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SUBSTR, 0); } public KW_SUBSTRING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SUBSTRING, 0); } public KW_FOR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FOR, 0); } public KW_TRIM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRIM, 0); } public KW_BOTH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BOTH, 0); } public KW_LEADING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LEADING, 0); } public KW_TRAILING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRAILING, 0); } public KW_OVERLAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVERLAY, 0); } public KW_PLACING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PLACING, 0); } public KW_WITHIN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WITHIN, 0); } public KW_GROUP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GROUP, 0); } public KW_ORDER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ORDER, 0); } public KW_BY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BY, 0); } public sortItem(): SortItemContext | undefined { return this.tryGetRuleContext(0, SortItemContext); } public KW_PERCENTILE_CONT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PERCENTILE_CONT, 0); } public KW_PERCENTILE_DISC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PERCENTILE_DISC, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_primaryExpression; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPrimaryExpression) { listener.enterPrimaryExpression(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPrimaryExpression) { listener.exitPrimaryExpression(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPrimaryExpression) { return visitor.visitPrimaryExpression(this); } else { return visitor.visitChildren(this); } } } export class LiteralTypeContext extends ParserRuleContext { public _unsupportedType!: IdentifierContext; public KW_DATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATE, 0); } public KW_TIMESTAMP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP, 0); } public KW_TIMESTAMP_LTZ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP_LTZ, 0); } public KW_TIMESTAMP_NTZ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP_NTZ, 0); } public KW_INTERVAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTERVAL, 0); } public KW_BINARY_HEX(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BINARY_HEX, 0); } public identifier(): IdentifierContext | undefined { return this.tryGetRuleContext(0, IdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_literalType; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterLiteralType) { listener.enterLiteralType(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitLiteralType) { listener.exitLiteralType(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitLiteralType) { return visitor.visitLiteralType(this); } else { return visitor.visitChildren(this); } } } export class ConstantContext extends ParserRuleContext { public KW_NULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULL, 0); } public QUESTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.QUESTION, 0); } public COLON(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.COLON, 0); } public identifier(): IdentifierContext | undefined { return this.tryGetRuleContext(0, IdentifierContext); } public interval(): IntervalContext | undefined { return this.tryGetRuleContext(0, IntervalContext); } public literalType(): LiteralTypeContext | undefined { return this.tryGetRuleContext(0, LiteralTypeContext); } public stringLit(): StringLitContext[]; public stringLit(i: number): StringLitContext; public stringLit(i?: number): StringLitContext | StringLitContext[] { if (i === undefined) { return this.getRuleContexts(StringLitContext); } else { return this.getRuleContext(i, StringLitContext); } } public number(): NumberContext | undefined { return this.tryGetRuleContext(0, NumberContext); } public booleanValue(): BooleanValueContext | undefined { return this.tryGetRuleContext(0, BooleanValueContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_constant; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterConstant) { listener.enterConstant(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitConstant) { listener.exitConstant(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitConstant) { return visitor.visitConstant(this); } else { return visitor.visitChildren(this); } } } export class ComparisonOperatorContext extends ParserRuleContext { public EQ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.EQ, 0); } public NEQ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.NEQ, 0); } public NEQJ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.NEQJ, 0); } public LT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LT, 0); } public LTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LTE, 0); } public GT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.GT, 0); } public GTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.GTE, 0); } public NSEQ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.NSEQ, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_comparisonOperator; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterComparisonOperator) { listener.enterComparisonOperator(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitComparisonOperator) { listener.exitComparisonOperator(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitComparisonOperator) { return visitor.visitComparisonOperator(this); } else { return visitor.visitChildren(this); } } } export class ArithmeticOperatorContext extends ParserRuleContext { public PLUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.PLUS, 0); } public MINUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.MINUS, 0); } public ASTERISK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.ASTERISK, 0); } public SLASH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.SLASH, 0); } public PERCENT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.PERCENT, 0); } public KW_DIV(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIV, 0); } public TILDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.TILDE, 0); } public AMPERSAND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.AMPERSAND, 0); } public PIPE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.PIPE, 0); } public CONCAT_PIPE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.CONCAT_PIPE, 0); } public HAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.HAT, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_arithmeticOperator; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterArithmeticOperator) { listener.enterArithmeticOperator(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitArithmeticOperator) { listener.exitArithmeticOperator(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitArithmeticOperator) { return visitor.visitArithmeticOperator(this); } else { return visitor.visitChildren(this); } } } export class PredicateOperatorContext extends ParserRuleContext { public KW_OR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OR, 0); } public KW_AND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AND, 0); } public KW_IN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IN, 0); } public KW_NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NOT, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_predicateOperator; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterPredicateOperator) { listener.enterPredicateOperator(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitPredicateOperator) { listener.exitPredicateOperator(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitPredicateOperator) { return visitor.visitPredicateOperator(this); } else { return visitor.visitChildren(this); } } } export class BooleanValueContext extends ParserRuleContext { public KW_TRUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRUE, 0); } public KW_FALSE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FALSE, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_booleanValue; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterBooleanValue) { listener.enterBooleanValue(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitBooleanValue) { listener.exitBooleanValue(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitBooleanValue) { return visitor.visitBooleanValue(this); } else { return visitor.visitChildren(this); } } } export class IntervalContext extends ParserRuleContext { public KW_INTERVAL(): TerminalNode { return this.getToken(SparkSqlParser.KW_INTERVAL, 0); } public errorCapturingMultiUnitsInterval(): ErrorCapturingMultiUnitsIntervalContext | undefined { return this.tryGetRuleContext(0, ErrorCapturingMultiUnitsIntervalContext); } public errorCapturingUnitToUnitInterval(): ErrorCapturingUnitToUnitIntervalContext | undefined { return this.tryGetRuleContext(0, ErrorCapturingUnitToUnitIntervalContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_interval; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterInterval) { listener.enterInterval(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitInterval) { listener.exitInterval(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitInterval) { return visitor.visitInterval(this); } else { return visitor.visitChildren(this); } } } export class ErrorCapturingMultiUnitsIntervalContext extends ParserRuleContext { public _body!: MultiUnitsIntervalContext; public multiUnitsInterval(): MultiUnitsIntervalContext { return this.getRuleContext(0, MultiUnitsIntervalContext); } public unitToUnitInterval(): UnitToUnitIntervalContext | undefined { return this.tryGetRuleContext(0, UnitToUnitIntervalContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_errorCapturingMultiUnitsInterval; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterErrorCapturingMultiUnitsInterval) { listener.enterErrorCapturingMultiUnitsInterval(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitErrorCapturingMultiUnitsInterval) { listener.exitErrorCapturingMultiUnitsInterval(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitErrorCapturingMultiUnitsInterval) { return visitor.visitErrorCapturingMultiUnitsInterval(this); } else { return visitor.visitChildren(this); } } } export class MultiUnitsIntervalContext extends ParserRuleContext { public _unitInMultiUnits!: UnitInMultiUnitsContext; public _unit: UnitInMultiUnitsContext[] = []; public intervalValue(): IntervalValueContext[]; public intervalValue(i: number): IntervalValueContext; public intervalValue(i?: number): IntervalValueContext | IntervalValueContext[] { if (i === undefined) { return this.getRuleContexts(IntervalValueContext); } else { return this.getRuleContext(i, IntervalValueContext); } } public unitInMultiUnits(): UnitInMultiUnitsContext[]; public unitInMultiUnits(i: number): UnitInMultiUnitsContext; public unitInMultiUnits(i?: number): UnitInMultiUnitsContext | UnitInMultiUnitsContext[] { if (i === undefined) { return this.getRuleContexts(UnitInMultiUnitsContext); } else { return this.getRuleContext(i, UnitInMultiUnitsContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_multiUnitsInterval; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterMultiUnitsInterval) { listener.enterMultiUnitsInterval(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitMultiUnitsInterval) { listener.exitMultiUnitsInterval(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitMultiUnitsInterval) { return visitor.visitMultiUnitsInterval(this); } else { return visitor.visitChildren(this); } } } export class ErrorCapturingUnitToUnitIntervalContext extends ParserRuleContext { public _body!: UnitToUnitIntervalContext; public _error1!: MultiUnitsIntervalContext; public _error2!: UnitToUnitIntervalContext; public unitToUnitInterval(): UnitToUnitIntervalContext[]; public unitToUnitInterval(i: number): UnitToUnitIntervalContext; public unitToUnitInterval(i?: number): UnitToUnitIntervalContext | UnitToUnitIntervalContext[] { if (i === undefined) { return this.getRuleContexts(UnitToUnitIntervalContext); } else { return this.getRuleContext(i, UnitToUnitIntervalContext); } } public multiUnitsInterval(): MultiUnitsIntervalContext | undefined { return this.tryGetRuleContext(0, MultiUnitsIntervalContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_errorCapturingUnitToUnitInterval; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterErrorCapturingUnitToUnitInterval) { listener.enterErrorCapturingUnitToUnitInterval(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitErrorCapturingUnitToUnitInterval) { listener.exitErrorCapturingUnitToUnitInterval(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitErrorCapturingUnitToUnitInterval) { return visitor.visitErrorCapturingUnitToUnitInterval(this); } else { return visitor.visitChildren(this); } } } export class UnitToUnitIntervalContext extends ParserRuleContext { public _value!: IntervalValueContext; public unitInUnitToUnit(): UnitInUnitToUnitContext[]; public unitInUnitToUnit(i: number): UnitInUnitToUnitContext; public unitInUnitToUnit(i?: number): UnitInUnitToUnitContext | UnitInUnitToUnitContext[] { if (i === undefined) { return this.getRuleContexts(UnitInUnitToUnitContext); } else { return this.getRuleContext(i, UnitInUnitToUnitContext); } } public KW_TO(): TerminalNode { return this.getToken(SparkSqlParser.KW_TO, 0); } public intervalValue(): IntervalValueContext { return this.getRuleContext(0, IntervalValueContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unitToUnitInterval; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnitToUnitInterval) { listener.enterUnitToUnitInterval(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnitToUnitInterval) { listener.exitUnitToUnitInterval(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnitToUnitInterval) { return visitor.visitUnitToUnitInterval(this); } else { return visitor.visitChildren(this); } } } export class IntervalValueContext extends ParserRuleContext { public INTEGER_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.INTEGER_VALUE, 0); } public DECIMAL_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.DECIMAL_VALUE, 0); } public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } public PLUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.PLUS, 0); } public MINUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.MINUS, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_intervalValue; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterIntervalValue) { listener.enterIntervalValue(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitIntervalValue) { listener.exitIntervalValue(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitIntervalValue) { return visitor.visitIntervalValue(this); } else { return visitor.visitChildren(this); } } } export class UnitInMultiUnitsContext extends ParserRuleContext { public KW_NANOSECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NANOSECOND, 0); } public KW_NANOSECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NANOSECONDS, 0); } public KW_MICROSECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MICROSECOND, 0); } public KW_MICROSECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MICROSECONDS, 0); } public KW_MILLISECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MILLISECOND, 0); } public KW_MILLISECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MILLISECONDS, 0); } public KW_SECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SECOND, 0); } public KW_SECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SECONDS, 0); } public KW_MINUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MINUTE, 0); } public KW_MINUTES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MINUTES, 0); } public KW_HOUR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_HOUR, 0); } public KW_HOURS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_HOURS, 0); } public KW_DAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAY, 0); } public KW_DAYS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAYS, 0); } public KW_WEEK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WEEK, 0); } public KW_WEEKS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WEEKS, 0); } public KW_MONTH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MONTH, 0); } public KW_MONTHS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MONTHS, 0); } public KW_YEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_YEAR, 0); } public KW_YEARS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_YEARS, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unitInMultiUnits; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnitInMultiUnits) { listener.enterUnitInMultiUnits(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnitInMultiUnits) { listener.exitUnitInMultiUnits(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnitInMultiUnits) { return visitor.visitUnitInMultiUnits(this); } else { return visitor.visitChildren(this); } } } export class UnitInUnitToUnitContext extends ParserRuleContext { public KW_SECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SECOND, 0); } public KW_MINUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MINUTE, 0); } public KW_HOUR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_HOUR, 0); } public KW_DAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAY, 0); } public KW_MONTH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MONTH, 0); } public KW_YEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_YEAR, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_unitInUnitToUnit; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterUnitInUnitToUnit) { listener.enterUnitInUnitToUnit(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitUnitInUnitToUnit) { listener.exitUnitInUnitToUnit(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitUnitInUnitToUnit) { return visitor.visitUnitInUnitToUnit(this); } else { return visitor.visitChildren(this); } } } export class ColPositionContext extends ParserRuleContext { public _position!: Token; public _afterCol!: ErrorCapturingIdentifierContext; public KW_FIRST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FIRST, 0); } public KW_AFTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AFTER, 0); } public errorCapturingIdentifier(): ErrorCapturingIdentifierContext | undefined { return this.tryGetRuleContext(0, ErrorCapturingIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_colPosition; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterColPosition) { listener.enterColPosition(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitColPosition) { listener.exitColPosition(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitColPosition) { return visitor.visitColPosition(this); } else { return visitor.visitChildren(this); } } } export class TypeContext extends ParserRuleContext { public _unsupportedType!: IdentifierContext; public KW_BOOLEAN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BOOLEAN, 0); } public KW_TINYINT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TINYINT, 0); } public KW_BYTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BYTE, 0); } public KW_SMALLINT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SMALLINT, 0); } public KW_SHORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SHORT, 0); } public KW_INT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INT, 0); } public KW_INTEGER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTEGER, 0); } public KW_BIGINT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BIGINT, 0); } public KW_LONG(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LONG, 0); } public KW_FLOAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FLOAT, 0); } public KW_REAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REAL, 0); } public KW_DOUBLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DOUBLE, 0); } public KW_DATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATE, 0); } public KW_TIMESTAMP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP, 0); } public KW_TIMESTAMP_NTZ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP_NTZ, 0); } public KW_TIMESTAMP_LTZ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP_LTZ, 0); } public KW_STRING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STRING, 0); } public KW_CHARACTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CHARACTER, 0); } public KW_CHAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CHAR, 0); } public KW_VARCHAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VARCHAR, 0); } public KW_BINARY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BINARY, 0); } public KW_DECIMAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DECIMAL, 0); } public KW_DEC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEC, 0); } public KW_NUMERIC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NUMERIC, 0); } public KW_VOID(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VOID, 0); } public KW_INTERVAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTERVAL, 0); } public KW_ARRAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ARRAY, 0); } public KW_STRUCT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STRUCT, 0); } public KW_MAP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MAP, 0); } public identifier(): IdentifierContext | undefined { return this.tryGetRuleContext(0, IdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_type; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterType) { listener.enterType(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitType) { listener.exitType(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitType) { return visitor.visitType(this); } else { return visitor.visitChildren(this); } } } export class DataTypeContext extends ParserRuleContext { public _complex!: Token; public LT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LT, 0); } public dataType(): DataTypeContext[]; public dataType(i: number): DataTypeContext; public dataType(i?: number): DataTypeContext | DataTypeContext[] { if (i === undefined) { return this.getRuleContexts(DataTypeContext); } else { return this.getRuleContext(i, DataTypeContext); } } public GT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.GT, 0); } public KW_ARRAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ARRAY, 0); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } public KW_MAP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MAP, 0); } public KW_STRUCT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STRUCT, 0); } public NEQ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.NEQ, 0); } public complexColTypeList(): ComplexColTypeListContext | undefined { return this.tryGetRuleContext(0, ComplexColTypeListContext); } public KW_INTERVAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTERVAL, 0); } public KW_YEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_YEAR, 0); } public KW_MONTH(): TerminalNode[]; public KW_MONTH(i: number): TerminalNode; public KW_MONTH(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_MONTH); } else { return this.getToken(SparkSqlParser.KW_MONTH, i); } } public KW_TO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TO, 0); } public KW_DAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAY, 0); } public KW_HOUR(): TerminalNode[]; public KW_HOUR(i: number): TerminalNode; public KW_HOUR(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_HOUR); } else { return this.getToken(SparkSqlParser.KW_HOUR, i); } } public KW_MINUTE(): TerminalNode[]; public KW_MINUTE(i: number): TerminalNode; public KW_MINUTE(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_MINUTE); } else { return this.getToken(SparkSqlParser.KW_MINUTE, i); } } public KW_SECOND(): TerminalNode[]; public KW_SECOND(i: number): TerminalNode; public KW_SECOND(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_SECOND); } else { return this.getToken(SparkSqlParser.KW_SECOND, i); } } public type(): TypeContext | undefined { return this.tryGetRuleContext(0, TypeContext); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public INTEGER_VALUE(): TerminalNode[]; public INTEGER_VALUE(i: number): TerminalNode; public INTEGER_VALUE(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.INTEGER_VALUE); } else { return this.getToken(SparkSqlParser.INTEGER_VALUE, i); } } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_dataType; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterDataType) { listener.enterDataType(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitDataType) { listener.exitDataType(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitDataType) { return visitor.visitDataType(this); } else { return visitor.visitChildren(this); } } } export class QualifiedColTypeWithPositionListContext extends ParserRuleContext { public qualifiedColTypeWithPosition(): QualifiedColTypeWithPositionContext[]; public qualifiedColTypeWithPosition(i: number): QualifiedColTypeWithPositionContext; public qualifiedColTypeWithPosition(i?: number): QualifiedColTypeWithPositionContext | QualifiedColTypeWithPositionContext[] { if (i === undefined) { return this.getRuleContexts(QualifiedColTypeWithPositionContext); } else { return this.getRuleContext(i, QualifiedColTypeWithPositionContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_qualifiedColTypeWithPositionList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterQualifiedColTypeWithPositionList) { listener.enterQualifiedColTypeWithPositionList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitQualifiedColTypeWithPositionList) { listener.exitQualifiedColTypeWithPositionList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitQualifiedColTypeWithPositionList) { return visitor.visitQualifiedColTypeWithPositionList(this); } else { return visitor.visitChildren(this); } } } export class QualifiedColTypeWithPositionContext extends ParserRuleContext { public _name!: MultipartIdentifierContext; public dataType(): DataTypeContext { return this.getRuleContext(0, DataTypeContext); } public multipartIdentifier(): MultipartIdentifierContext { return this.getRuleContext(0, MultipartIdentifierContext); } public colDefinitionDescriptorWithPosition(): ColDefinitionDescriptorWithPositionContext[]; public colDefinitionDescriptorWithPosition(i: number): ColDefinitionDescriptorWithPositionContext; public colDefinitionDescriptorWithPosition(i?: number): ColDefinitionDescriptorWithPositionContext | ColDefinitionDescriptorWithPositionContext[] { if (i === undefined) { return this.getRuleContexts(ColDefinitionDescriptorWithPositionContext); } else { return this.getRuleContext(i, ColDefinitionDescriptorWithPositionContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_qualifiedColTypeWithPosition; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterQualifiedColTypeWithPosition) { listener.enterQualifiedColTypeWithPosition(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitQualifiedColTypeWithPosition) { listener.exitQualifiedColTypeWithPosition(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitQualifiedColTypeWithPosition) { return visitor.visitQualifiedColTypeWithPosition(this); } else { return visitor.visitChildren(this); } } } export class ColDefinitionDescriptorWithPositionContext extends ParserRuleContext { public KW_NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NOT, 0); } public KW_NULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULL, 0); } public defaultExpression(): DefaultExpressionContext | undefined { return this.tryGetRuleContext(0, DefaultExpressionContext); } public commentSpec(): CommentSpecContext | undefined { return this.tryGetRuleContext(0, CommentSpecContext); } public colPosition(): ColPositionContext | undefined { return this.tryGetRuleContext(0, ColPositionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_colDefinitionDescriptorWithPosition; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterColDefinitionDescriptorWithPosition) { listener.enterColDefinitionDescriptorWithPosition(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitColDefinitionDescriptorWithPosition) { listener.exitColDefinitionDescriptorWithPosition(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitColDefinitionDescriptorWithPosition) { return visitor.visitColDefinitionDescriptorWithPosition(this); } else { return visitor.visitChildren(this); } } } export class DefaultExpressionContext extends ParserRuleContext { public KW_DEFAULT(): TerminalNode { return this.getToken(SparkSqlParser.KW_DEFAULT, 0); } public expression(): ExpressionContext { return this.getRuleContext(0, ExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_defaultExpression; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterDefaultExpression) { listener.enterDefaultExpression(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitDefaultExpression) { listener.exitDefaultExpression(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitDefaultExpression) { return visitor.visitDefaultExpression(this); } else { return visitor.visitChildren(this); } } } export class VariableDefaultExpressionContext extends ParserRuleContext { public expression(): ExpressionContext { return this.getRuleContext(0, ExpressionContext); } public KW_DEFAULT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEFAULT, 0); } public EQ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.EQ, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_variableDefaultExpression; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterVariableDefaultExpression) { listener.enterVariableDefaultExpression(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitVariableDefaultExpression) { listener.exitVariableDefaultExpression(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitVariableDefaultExpression) { return visitor.visitVariableDefaultExpression(this); } else { return visitor.visitChildren(this); } } } export class ColTypeListContext extends ParserRuleContext { public colType(): ColTypeContext[]; public colType(i: number): ColTypeContext; public colType(i?: number): ColTypeContext | ColTypeContext[] { if (i === undefined) { return this.getRuleContexts(ColTypeContext); } else { return this.getRuleContext(i, ColTypeContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_colTypeList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterColTypeList) { listener.enterColTypeList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitColTypeList) { listener.exitColTypeList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitColTypeList) { return visitor.visitColTypeList(this); } else { return visitor.visitChildren(this); } } } export class ColTypeContext extends ParserRuleContext { public _colName!: ErrorCapturingIdentifierContext; public dataType(): DataTypeContext { return this.getRuleContext(0, DataTypeContext); } public errorCapturingIdentifier(): ErrorCapturingIdentifierContext { return this.getRuleContext(0, ErrorCapturingIdentifierContext); } public KW_NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NOT, 0); } public KW_NULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULL, 0); } public commentSpec(): CommentSpecContext | undefined { return this.tryGetRuleContext(0, CommentSpecContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_colType; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterColType) { listener.enterColType(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitColType) { listener.exitColType(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitColType) { return visitor.visitColType(this); } else { return visitor.visitChildren(this); } } } export class CreateOrReplaceTableColTypeListContext extends ParserRuleContext { public createOrReplaceTableColType(): CreateOrReplaceTableColTypeContext[]; public createOrReplaceTableColType(i: number): CreateOrReplaceTableColTypeContext; public createOrReplaceTableColType(i?: number): CreateOrReplaceTableColTypeContext | CreateOrReplaceTableColTypeContext[] { if (i === undefined) { return this.getRuleContexts(CreateOrReplaceTableColTypeContext); } else { return this.getRuleContext(i, CreateOrReplaceTableColTypeContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_createOrReplaceTableColTypeList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterCreateOrReplaceTableColTypeList) { listener.enterCreateOrReplaceTableColTypeList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitCreateOrReplaceTableColTypeList) { listener.exitCreateOrReplaceTableColTypeList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitCreateOrReplaceTableColTypeList) { return visitor.visitCreateOrReplaceTableColTypeList(this); } else { return visitor.visitChildren(this); } } } export class CreateOrReplaceTableColTypeContext extends ParserRuleContext { public _colName!: ErrorCapturingIdentifierContext; public dataType(): DataTypeContext { return this.getRuleContext(0, DataTypeContext); } public errorCapturingIdentifier(): ErrorCapturingIdentifierContext { return this.getRuleContext(0, ErrorCapturingIdentifierContext); } public colDefinitionOption(): ColDefinitionOptionContext[]; public colDefinitionOption(i: number): ColDefinitionOptionContext; public colDefinitionOption(i?: number): ColDefinitionOptionContext | ColDefinitionOptionContext[] { if (i === undefined) { return this.getRuleContexts(ColDefinitionOptionContext); } else { return this.getRuleContext(i, ColDefinitionOptionContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_createOrReplaceTableColType; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterCreateOrReplaceTableColType) { listener.enterCreateOrReplaceTableColType(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitCreateOrReplaceTableColType) { listener.exitCreateOrReplaceTableColType(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitCreateOrReplaceTableColType) { return visitor.visitCreateOrReplaceTableColType(this); } else { return visitor.visitChildren(this); } } } export class ColDefinitionOptionContext extends ParserRuleContext { public KW_NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NOT, 0); } public KW_NULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULL, 0); } public defaultExpression(): DefaultExpressionContext | undefined { return this.tryGetRuleContext(0, DefaultExpressionContext); } public generationExpression(): GenerationExpressionContext | undefined { return this.tryGetRuleContext(0, GenerationExpressionContext); } public commentSpec(): CommentSpecContext | undefined { return this.tryGetRuleContext(0, CommentSpecContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_colDefinitionOption; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterColDefinitionOption) { listener.enterColDefinitionOption(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitColDefinitionOption) { listener.exitColDefinitionOption(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitColDefinitionOption) { return visitor.visitColDefinitionOption(this); } else { return visitor.visitChildren(this); } } } export class GenerationExpressionContext extends ParserRuleContext { public KW_GENERATED(): TerminalNode { return this.getToken(SparkSqlParser.KW_GENERATED, 0); } public KW_ALWAYS(): TerminalNode { return this.getToken(SparkSqlParser.KW_ALWAYS, 0); } public KW_AS(): TerminalNode { return this.getToken(SparkSqlParser.KW_AS, 0); } public LEFT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.LEFT_PAREN, 0); } public expression(): ExpressionContext { return this.getRuleContext(0, ExpressionContext); } public RIGHT_PAREN(): TerminalNode { return this.getToken(SparkSqlParser.RIGHT_PAREN, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_generationExpression; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterGenerationExpression) { listener.enterGenerationExpression(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitGenerationExpression) { listener.exitGenerationExpression(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitGenerationExpression) { return visitor.visitGenerationExpression(this); } else { return visitor.visitChildren(this); } } } export class ComplexColTypeListContext extends ParserRuleContext { public complexColType(): ComplexColTypeContext[]; public complexColType(i: number): ComplexColTypeContext; public complexColType(i?: number): ComplexColTypeContext | ComplexColTypeContext[] { if (i === undefined) { return this.getRuleContexts(ComplexColTypeContext); } else { return this.getRuleContext(i, ComplexColTypeContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_complexColTypeList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterComplexColTypeList) { listener.enterComplexColTypeList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitComplexColTypeList) { listener.exitComplexColTypeList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitComplexColTypeList) { return visitor.visitComplexColTypeList(this); } else { return visitor.visitChildren(this); } } } export class ComplexColTypeContext extends ParserRuleContext { public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } public dataType(): DataTypeContext { return this.getRuleContext(0, DataTypeContext); } public COLON(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.COLON, 0); } public KW_NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NOT, 0); } public KW_NULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULL, 0); } public commentSpec(): CommentSpecContext | undefined { return this.tryGetRuleContext(0, CommentSpecContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_complexColType; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterComplexColType) { listener.enterComplexColType(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitComplexColType) { listener.exitComplexColType(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitComplexColType) { return visitor.visitComplexColType(this); } else { return visitor.visitChildren(this); } } } export class WhenClauseContext extends ParserRuleContext { public _condition!: ExpressionContext; public _result!: ExpressionContext; public KW_WHEN(): TerminalNode { return this.getToken(SparkSqlParser.KW_WHEN, 0); } public KW_THEN(): TerminalNode { return this.getToken(SparkSqlParser.KW_THEN, 0); } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_whenClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterWhenClause) { listener.enterWhenClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitWhenClause) { listener.exitWhenClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitWhenClause) { return visitor.visitWhenClause(this); } else { return visitor.visitChildren(this); } } } export class WindowClauseContext extends ParserRuleContext { public KW_WINDOW(): TerminalNode { return this.getToken(SparkSqlParser.KW_WINDOW, 0); } public namedWindow(): NamedWindowContext[]; public namedWindow(i: number): NamedWindowContext; public namedWindow(i?: number): NamedWindowContext | NamedWindowContext[] { if (i === undefined) { return this.getRuleContexts(NamedWindowContext); } else { return this.getRuleContext(i, NamedWindowContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_windowClause; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterWindowClause) { listener.enterWindowClause(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitWindowClause) { listener.exitWindowClause(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitWindowClause) { return visitor.visitWindowClause(this); } else { return visitor.visitChildren(this); } } } export class NamedWindowContext extends ParserRuleContext { public _name!: ErrorCapturingIdentifierContext; public KW_AS(): TerminalNode { return this.getToken(SparkSqlParser.KW_AS, 0); } public windowSpec(): WindowSpecContext { return this.getRuleContext(0, WindowSpecContext); } public errorCapturingIdentifier(): ErrorCapturingIdentifierContext { return this.getRuleContext(0, ErrorCapturingIdentifierContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_namedWindow; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNamedWindow) { listener.enterNamedWindow(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNamedWindow) { listener.exitNamedWindow(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNamedWindow) { return visitor.visitNamedWindow(this); } else { return visitor.visitChildren(this); } } } export class WindowSpecContext extends ParserRuleContext { public _name!: ErrorCapturingIdentifierContext; public _expression!: ExpressionContext; public _partition: ExpressionContext[] = []; public errorCapturingIdentifier(): ErrorCapturingIdentifierContext | undefined { return this.tryGetRuleContext(0, ErrorCapturingIdentifierContext); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public KW_CLUSTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CLUSTER, 0); } public KW_BY(): TerminalNode[]; public KW_BY(i: number): TerminalNode; public KW_BY(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.KW_BY); } else { return this.getToken(SparkSqlParser.KW_BY, i); } } public expression(): ExpressionContext[]; public expression(i: number): ExpressionContext; public expression(i?: number): ExpressionContext | ExpressionContext[] { if (i === undefined) { return this.getRuleContexts(ExpressionContext); } else { return this.getRuleContext(i, ExpressionContext); } } public windowFrame(): WindowFrameContext | undefined { return this.tryGetRuleContext(0, WindowFrameContext); } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } public sortItem(): SortItemContext[]; public sortItem(i: number): SortItemContext; public sortItem(i?: number): SortItemContext | SortItemContext[] { if (i === undefined) { return this.getRuleContexts(SortItemContext); } else { return this.getRuleContext(i, SortItemContext); } } public KW_PARTITION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PARTITION, 0); } public KW_DISTRIBUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DISTRIBUTE, 0); } public KW_ORDER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ORDER, 0); } public KW_SORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SORT, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_windowSpec; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterWindowSpec) { listener.enterWindowSpec(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitWindowSpec) { listener.exitWindowSpec(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitWindowSpec) { return visitor.visitWindowSpec(this); } else { return visitor.visitChildren(this); } } } export class WindowFrameContext extends ParserRuleContext { public _frameType!: Token; public _start_!: FrameBoundContext; public _end!: FrameBoundContext; public KW_RANGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RANGE, 0); } public frameBound(): FrameBoundContext[]; public frameBound(i: number): FrameBoundContext; public frameBound(i?: number): FrameBoundContext | FrameBoundContext[] { if (i === undefined) { return this.getRuleContexts(FrameBoundContext); } else { return this.getRuleContext(i, FrameBoundContext); } } public KW_ROWS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROWS, 0); } public KW_BETWEEN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BETWEEN, 0); } public KW_AND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AND, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_windowFrame; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterWindowFrame) { listener.enterWindowFrame(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitWindowFrame) { listener.exitWindowFrame(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitWindowFrame) { return visitor.visitWindowFrame(this); } else { return visitor.visitChildren(this); } } } export class FrameBoundContext extends ParserRuleContext { public _boundType!: Token; public KW_UNBOUNDED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNBOUNDED, 0); } public KW_PRECEDING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PRECEDING, 0); } public KW_FOLLOWING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FOLLOWING, 0); } public KW_ROW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROW, 0); } public KW_CURRENT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT, 0); } public expression(): ExpressionContext | undefined { return this.tryGetRuleContext(0, ExpressionContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_frameBound; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFrameBound) { listener.enterFrameBound(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFrameBound) { listener.exitFrameBound(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFrameBound) { return visitor.visitFrameBound(this); } else { return visitor.visitChildren(this); } } } export class QualifiedNameListContext extends ParserRuleContext { public qualifiedName(): QualifiedNameContext[]; public qualifiedName(i: number): QualifiedNameContext; public qualifiedName(i?: number): QualifiedNameContext | QualifiedNameContext[] { if (i === undefined) { return this.getRuleContexts(QualifiedNameContext); } else { return this.getRuleContext(i, QualifiedNameContext); } } public COMMA(): TerminalNode[]; public COMMA(i: number): TerminalNode; public COMMA(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.COMMA); } else { return this.getToken(SparkSqlParser.COMMA, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_qualifiedNameList; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterQualifiedNameList) { listener.enterQualifiedNameList(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitQualifiedNameList) { listener.exitQualifiedNameList(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitQualifiedNameList) { return visitor.visitQualifiedNameList(this); } else { return visitor.visitChildren(this); } } } export class FunctionNameContext extends ParserRuleContext { public KW_IDENTIFIER_KW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IDENTIFIER_KW, 0); } public LEFT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.LEFT_PAREN, 0); } public expression(): ExpressionContext | undefined { return this.tryGetRuleContext(0, ExpressionContext); } public RIGHT_PAREN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.RIGHT_PAREN, 0); } public qualifiedName(): QualifiedNameContext | undefined { return this.tryGetRuleContext(0, QualifiedNameContext); } public KW_FILTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FILTER, 0); } public KW_LEFT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LEFT, 0); } public KW_RIGHT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RIGHT, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_functionName; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFunctionName) { listener.enterFunctionName(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFunctionName) { listener.exitFunctionName(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFunctionName) { return visitor.visitFunctionName(this); } else { return visitor.visitChildren(this); } } } export class FunctionNameCreateContext extends ParserRuleContext { public qualifiedName(): QualifiedNameContext { return this.getRuleContext(0, QualifiedNameContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_functionNameCreate; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterFunctionNameCreate) { listener.enterFunctionNameCreate(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitFunctionNameCreate) { listener.exitFunctionNameCreate(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitFunctionNameCreate) { return visitor.visitFunctionNameCreate(this); } else { return visitor.visitChildren(this); } } } export class QualifiedNameContext extends ParserRuleContext { public identifier(): IdentifierContext[]; public identifier(i: number): IdentifierContext; public identifier(i?: number): IdentifierContext | IdentifierContext[] { if (i === undefined) { return this.getRuleContexts(IdentifierContext); } else { return this.getRuleContext(i, IdentifierContext); } } public DOT(): TerminalNode[]; public DOT(i: number): TerminalNode; public DOT(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.DOT); } else { return this.getToken(SparkSqlParser.DOT, i); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_qualifiedName; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterQualifiedName) { listener.enterQualifiedName(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitQualifiedName) { listener.exitQualifiedName(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitQualifiedName) { return visitor.visitQualifiedName(this); } else { return visitor.visitChildren(this); } } } export class ErrorCapturingIdentifierContext extends ParserRuleContext { public identifier(): IdentifierContext { return this.getRuleContext(0, IdentifierContext); } public errorCapturingIdentifierExtra(): ErrorCapturingIdentifierExtraContext { return this.getRuleContext(0, ErrorCapturingIdentifierExtraContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_errorCapturingIdentifier; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterErrorCapturingIdentifier) { listener.enterErrorCapturingIdentifier(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitErrorCapturingIdentifier) { listener.exitErrorCapturingIdentifier(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitErrorCapturingIdentifier) { return visitor.visitErrorCapturingIdentifier(this); } else { return visitor.visitChildren(this); } } } export class ErrorCapturingIdentifierExtraContext extends ParserRuleContext { public MINUS(): TerminalNode[]; public MINUS(i: number): TerminalNode; public MINUS(i?: number): TerminalNode | TerminalNode[] { if (i === undefined) { return this.getTokens(SparkSqlParser.MINUS); } else { return this.getToken(SparkSqlParser.MINUS, i); } } public identifier(): IdentifierContext[]; public identifier(i: number): IdentifierContext; public identifier(i?: number): IdentifierContext | IdentifierContext[] { if (i === undefined) { return this.getRuleContexts(IdentifierContext); } else { return this.getRuleContext(i, IdentifierContext); } } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_errorCapturingIdentifierExtra; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterErrorCapturingIdentifierExtra) { listener.enterErrorCapturingIdentifierExtra(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitErrorCapturingIdentifierExtra) { listener.exitErrorCapturingIdentifierExtra(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitErrorCapturingIdentifierExtra) { return visitor.visitErrorCapturingIdentifierExtra(this); } else { return visitor.visitChildren(this); } } } export class IdentifierContext extends ParserRuleContext { public strictIdentifier(): StrictIdentifierContext | undefined { return this.tryGetRuleContext(0, StrictIdentifierContext); } public strictNonReserved(): StrictNonReservedContext | undefined { return this.tryGetRuleContext(0, StrictNonReservedContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_identifier; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterIdentifier) { listener.enterIdentifier(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitIdentifier) { listener.exitIdentifier(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitIdentifier) { return visitor.visitIdentifier(this); } else { return visitor.visitChildren(this); } } } export class StrictIdentifierContext extends ParserRuleContext { public IDENTIFIER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.IDENTIFIER, 0); } public quotedIdentifier(): QuotedIdentifierContext | undefined { return this.tryGetRuleContext(0, QuotedIdentifierContext); } public ansiNonReserved(): AnsiNonReservedContext | undefined { return this.tryGetRuleContext(0, AnsiNonReservedContext); } public nonReserved(): NonReservedContext | undefined { return this.tryGetRuleContext(0, NonReservedContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_strictIdentifier; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterStrictIdentifier) { listener.enterStrictIdentifier(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitStrictIdentifier) { listener.exitStrictIdentifier(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitStrictIdentifier) { return visitor.visitStrictIdentifier(this); } else { return visitor.visitChildren(this); } } } export class QuotedIdentifierContext extends ParserRuleContext { public BACKQUOTED_IDENTIFIER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.BACKQUOTED_IDENTIFIER, 0); } public DOUBLEQUOTED_STRING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.DOUBLEQUOTED_STRING, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_quotedIdentifier; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterQuotedIdentifier) { listener.enterQuotedIdentifier(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitQuotedIdentifier) { listener.exitQuotedIdentifier(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitQuotedIdentifier) { return visitor.visitQuotedIdentifier(this); } else { return visitor.visitChildren(this); } } } export class BackQuotedIdentifierContext extends ParserRuleContext { public BACKQUOTED_IDENTIFIER(): TerminalNode { return this.getToken(SparkSqlParser.BACKQUOTED_IDENTIFIER, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_backQuotedIdentifier; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterBackQuotedIdentifier) { listener.enterBackQuotedIdentifier(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitBackQuotedIdentifier) { listener.exitBackQuotedIdentifier(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitBackQuotedIdentifier) { return visitor.visitBackQuotedIdentifier(this); } else { return visitor.visitChildren(this); } } } export class NumberContext extends ParserRuleContext { public EXPONENT_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.EXPONENT_VALUE, 0); } public MINUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.MINUS, 0); } public DECIMAL_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.DECIMAL_VALUE, 0); } public INTEGER_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.INTEGER_VALUE, 0); } public BIGINT_LITERAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.BIGINT_LITERAL, 0); } public SMALLINT_LITERAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.SMALLINT_LITERAL, 0); } public TINYINT_LITERAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.TINYINT_LITERAL, 0); } public DOUBLE_LITERAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.DOUBLE_LITERAL, 0); } public FLOAT_LITERAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.FLOAT_LITERAL, 0); } public BIGDECIMAL_LITERAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.BIGDECIMAL_LITERAL, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_number; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNumber) { listener.enterNumber(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNumber) { listener.exitNumber(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNumber) { return visitor.visitNumber(this); } else { return visitor.visitChildren(this); } } } export class AlterColumnActionContext extends ParserRuleContext { public _setOrDrop!: Token; public _dropDefault!: Token; public KW_TYPE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TYPE, 0); } public dataType(): DataTypeContext | undefined { return this.tryGetRuleContext(0, DataTypeContext); } public commentSpec(): CommentSpecContext | undefined { return this.tryGetRuleContext(0, CommentSpecContext); } public colPosition(): ColPositionContext | undefined { return this.tryGetRuleContext(0, ColPositionContext); } public KW_NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NOT, 0); } public KW_NULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULL, 0); } public KW_SET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SET, 0); } public KW_DROP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DROP, 0); } public defaultExpression(): DefaultExpressionContext | undefined { return this.tryGetRuleContext(0, DefaultExpressionContext); } public KW_DEFAULT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEFAULT, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_alterColumnAction; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterAlterColumnAction) { listener.enterAlterColumnAction(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitAlterColumnAction) { listener.exitAlterColumnAction(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitAlterColumnAction) { return visitor.visitAlterColumnAction(this); } else { return visitor.visitChildren(this); } } } export class StringLitContext extends ParserRuleContext { public STRING_LITERAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.STRING_LITERAL, 0); } public DOUBLEQUOTED_STRING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.DOUBLEQUOTED_STRING, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_stringLit; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterStringLit) { listener.enterStringLit(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitStringLit) { listener.exitStringLit(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitStringLit) { return visitor.visitStringLit(this); } else { return visitor.visitChildren(this); } } } export class CommentContext extends ParserRuleContext { public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } public KW_NULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULL, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_comment; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterComment) { listener.enterComment(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitComment) { listener.exitComment(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitComment) { return visitor.visitComment(this); } else { return visitor.visitChildren(this); } } } export class VersionContext extends ParserRuleContext { public INTEGER_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.INTEGER_VALUE, 0); } public stringLit(): StringLitContext | undefined { return this.tryGetRuleContext(0, StringLitContext); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_version; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterVersion) { listener.enterVersion(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitVersion) { listener.exitVersion(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitVersion) { return visitor.visitVersion(this); } else { return visitor.visitChildren(this); } } } export class AnsiNonReservedContext extends ParserRuleContext { public KW_ADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ADD, 0); } public KW_AFTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AFTER, 0); } public KW_ALTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALTER, 0); } public KW_ALWAYS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALWAYS, 0); } public KW_ANALYZE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANALYZE, 0); } public KW_ANTI(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANTI, 0); } public KW_ANY_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANY_VALUE, 0); } public KW_ARCHIVE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ARCHIVE, 0); } public KW_ARRAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ARRAY, 0); } public KW_ASC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ASC, 0); } public KW_AT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AT, 0); } public KW_BETWEEN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BETWEEN, 0); } public KW_BIGINT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BIGINT, 0); } public KW_BINARY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BINARY, 0); } public KW_BINARY_HEX(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BINARY_HEX, 0); } public KW_BOOLEAN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BOOLEAN, 0); } public KW_BUCKET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BUCKET, 0); } public KW_BUCKETS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BUCKETS, 0); } public KW_BY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BY, 0); } public KW_BYTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BYTE, 0); } public KW_CACHE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CACHE, 0); } public KW_CASCADE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CASCADE, 0); } public KW_CATALOG(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CATALOG, 0); } public KW_CATALOGS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CATALOGS, 0); } public KW_CHANGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CHANGE, 0); } public KW_CHAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CHAR, 0); } public KW_CHARACTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CHARACTER, 0); } public KW_CLEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CLEAR, 0); } public KW_CLUSTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CLUSTER, 0); } public KW_CLUSTERED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CLUSTERED, 0); } public KW_CODEGEN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CODEGEN, 0); } public KW_COLLECTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COLLECTION, 0); } public KW_COLUMNS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COLUMNS, 0); } public KW_COMMENT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMMENT, 0); } public KW_COMMIT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMMIT, 0); } public KW_COMPACT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMPACT, 0); } public KW_COMPACTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMPACTIONS, 0); } public KW_COMPUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMPUTE, 0); } public KW_CONCATENATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CONCATENATE, 0); } public KW_COST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COST, 0); } public KW_CUBE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CUBE, 0); } public KW_CURRENT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT, 0); } public KW_DATA(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATA, 0); } public KW_DATABASE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATABASE, 0); } public KW_DATABASES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATABASES, 0); } public KW_DATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATE, 0); } public KW_DATEADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATEADD, 0); } public KW_DATE_ADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATE_ADD, 0); } public KW_DATEDIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATEDIFF, 0); } public KW_DATE_DIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATE_DIFF, 0); } public KW_DAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAY, 0); } public KW_DAYS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAYS, 0); } public KW_DAYOFYEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAYOFYEAR, 0); } public KW_DBPROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DBPROPERTIES, 0); } public KW_DEC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEC, 0); } public KW_DECIMAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DECIMAL, 0); } public KW_DECLARE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DECLARE, 0); } public KW_DEFAULT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEFAULT, 0); } public KW_DEFINED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEFINED, 0); } public KW_DELETE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DELETE, 0); } public KW_DELIMITED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DELIMITED, 0); } public KW_DESC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DESC, 0); } public KW_DESCRIBE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DESCRIBE, 0); } public KW_DFS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DFS, 0); } public KW_DIRECTORIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIRECTORIES, 0); } public KW_DIRECTORY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIRECTORY, 0); } public KW_DISTRIBUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DISTRIBUTE, 0); } public KW_DIV(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIV, 0); } public KW_DOUBLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DOUBLE, 0); } public KW_DROP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DROP, 0); } public KW_ESCAPED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ESCAPED, 0); } public KW_EXCHANGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXCHANGE, 0); } public KW_EXCLUDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXCLUDE, 0); } public KW_EXISTS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXISTS, 0); } public KW_EXPLAIN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXPLAIN, 0); } public KW_EXPORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXPORT, 0); } public KW_EXTENDED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXTENDED, 0); } public KW_EXTERNAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXTERNAL, 0); } public KW_EXTRACT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXTRACT, 0); } public KW_FIELDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FIELDS, 0); } public KW_FILEFORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FILEFORMAT, 0); } public KW_FIRST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FIRST, 0); } public KW_FLOAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FLOAT, 0); } public KW_FOLLOWING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FOLLOWING, 0); } public KW_FORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FORMAT, 0); } public KW_FORMATTED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FORMATTED, 0); } public KW_FUNCTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FUNCTION, 0); } public KW_FUNCTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FUNCTIONS, 0); } public KW_GENERATED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GENERATED, 0); } public KW_GLOBAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GLOBAL, 0); } public KW_GROUPING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GROUPING, 0); } public KW_HOUR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_HOUR, 0); } public KW_HOURS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_HOURS, 0); } public KW_IDENTIFIER_KW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IDENTIFIER_KW, 0); } public KW_IF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IF, 0); } public KW_IGNORE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IGNORE, 0); } public KW_IMPORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IMPORT, 0); } public KW_INCLUDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INCLUDE, 0); } public KW_INDEX(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INDEX, 0); } public KW_INDEXES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INDEXES, 0); } public KW_INPATH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INPATH, 0); } public KW_INPUTFORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INPUTFORMAT, 0); } public KW_INSERT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INSERT, 0); } public KW_INT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INT, 0); } public KW_INTEGER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTEGER, 0); } public KW_INTERVAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTERVAL, 0); } public KW_ITEMS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ITEMS, 0); } public KW_KEYS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_KEYS, 0); } public KW_LAST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LAST, 0); } public KW_LAZY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LAZY, 0); } public KW_LIKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LIKE, 0); } public KW_ILIKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ILIKE, 0); } public KW_LIMIT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LIMIT, 0); } public KW_LINES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LINES, 0); } public KW_LIST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LIST, 0); } public KW_LOAD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOAD, 0); } public KW_LOCAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCAL, 0); } public KW_LOCATION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCATION, 0); } public KW_LOCK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCK, 0); } public KW_LOCKS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCKS, 0); } public KW_LOGICAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOGICAL, 0); } public KW_LONG(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LONG, 0); } public KW_MACRO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MACRO, 0); } public KW_MAP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MAP, 0); } public KW_MATCHED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MATCHED, 0); } public KW_MERGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MERGE, 0); } public KW_MICROSECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MICROSECOND, 0); } public KW_MICROSECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MICROSECONDS, 0); } public KW_MILLISECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MILLISECOND, 0); } public KW_MILLISECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MILLISECONDS, 0); } public KW_MINUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MINUTE, 0); } public KW_MINUTES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MINUTES, 0); } public KW_MONTH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MONTH, 0); } public KW_MONTHS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MONTHS, 0); } public KW_MSCK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MSCK, 0); } public KW_NAME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NAME, 0); } public KW_NAMESPACE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NAMESPACE, 0); } public KW_NAMESPACES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NAMESPACES, 0); } public KW_NANOSECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NANOSECOND, 0); } public KW_NANOSECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NANOSECONDS, 0); } public KW_NO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NO, 0); } public KW_NULLS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULLS, 0); } public KW_NUMERIC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NUMERIC, 0); } public KW_OF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OF, 0); } public KW_OPTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OPTION, 0); } public KW_OPTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OPTIONS, 0); } public KW_OUT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OUT, 0); } public KW_OUTPUTFORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OUTPUTFORMAT, 0); } public KW_OVER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVER, 0); } public KW_OVERLAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVERLAY, 0); } public KW_OVERWRITE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVERWRITE, 0); } public KW_PARTITION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PARTITION, 0); } public KW_PARTITIONED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PARTITIONED, 0); } public KW_PARTITIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PARTITIONS, 0); } public KW_PERCENTLIT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PERCENTLIT, 0); } public KW_PIVOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PIVOT, 0); } public KW_PLACING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PLACING, 0); } public KW_POSITION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_POSITION, 0); } public KW_PRECEDING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PRECEDING, 0); } public KW_PRINCIPALS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PRINCIPALS, 0); } public KW_PROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PROPERTIES, 0); } public KW_PURGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PURGE, 0); } public KW_QUARTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_QUARTER, 0); } public KW_QUERY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_QUERY, 0); } public KW_RANGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RANGE, 0); } public KW_REAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REAL, 0); } public KW_RECORDREADER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RECORDREADER, 0); } public KW_RECORDWRITER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RECORDWRITER, 0); } public KW_RECOVER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RECOVER, 0); } public KW_REDUCE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REDUCE, 0); } public KW_REFRESH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REFRESH, 0); } public KW_RENAME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RENAME, 0); } public KW_REPAIR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPAIR, 0); } public KW_REPEATABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPEATABLE, 0); } public KW_REPLACE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPLACE, 0); } public KW_RESET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RESET, 0); } public KW_RESPECT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RESPECT, 0); } public KW_RESTRICT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RESTRICT, 0); } public KW_REVOKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REVOKE, 0); } public KW_RLIKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RLIKE, 0); } public KW_REGEXP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REGEXP, 0); } public KW_ROLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLE, 0); } public KW_ROLES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLES, 0); } public KW_ROLLBACK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLLBACK, 0); } public KW_ROLLUP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLLUP, 0); } public KW_ROW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROW, 0); } public KW_ROWS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROWS, 0); } public KW_SCHEMA(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SCHEMA, 0); } public KW_SCHEMAS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SCHEMAS, 0); } public KW_SECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SECOND, 0); } public KW_SECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SECONDS, 0); } public KW_SEMI(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SEMI, 0); } public KW_SEPARATED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SEPARATED, 0); } public KW_SERDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SERDE, 0); } public KW_SERDEPROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SERDEPROPERTIES, 0); } public KW_SET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SET, 0); } public KW_SETMINUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SETMINUS, 0); } public KW_SETS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SETS, 0); } public KW_SHORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SHORT, 0); } public KW_SHOW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SHOW, 0); } public KW_SINGLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SINGLE, 0); } public KW_SKEWED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SKEWED, 0); } public KW_SMALLINT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SMALLINT, 0); } public KW_SORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SORT, 0); } public KW_SORTED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SORTED, 0); } public KW_SOURCE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SOURCE, 0); } public KW_START(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_START, 0); } public KW_STATISTICS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STATISTICS, 0); } public KW_STORED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STORED, 0); } public KW_STRATIFY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STRATIFY, 0); } public KW_STRING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STRING, 0); } public KW_STRUCT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STRUCT, 0); } public KW_SUBSTR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SUBSTR, 0); } public KW_SUBSTRING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SUBSTRING, 0); } public KW_SYNC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYNC, 0); } public KW_SYSTEM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYSTEM, 0); } public KW_SYSTEM_TIME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYSTEM_TIME, 0); } public KW_SYSTEM_VERSION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYSTEM_VERSION, 0); } public KW_TABLES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TABLES, 0); } public KW_TABLESAMPLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TABLESAMPLE, 0); } public KW_TARGET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TARGET, 0); } public KW_TBLPROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TBLPROPERTIES, 0); } public KW_TEMPORARY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TEMPORARY, 0); } public KW_TERMINATED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TERMINATED, 0); } public KW_TIMEDIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMEDIFF, 0); } public KW_TIMESTAMP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP, 0); } public KW_TIMESTAMP_LTZ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP_LTZ, 0); } public KW_TIMESTAMP_NTZ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP_NTZ, 0); } public KW_TIMESTAMPADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMPADD, 0); } public KW_TIMESTAMPDIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMPDIFF, 0); } public KW_TINYINT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TINYINT, 0); } public KW_TOUCH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TOUCH, 0); } public KW_TRANSACTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRANSACTION, 0); } public KW_TRANSACTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRANSACTIONS, 0); } public KW_TRANSFORM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRANSFORM, 0); } public KW_TRIM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRIM, 0); } public KW_TRUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRUE, 0); } public KW_TRUNCATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRUNCATE, 0); } public KW_TRY_CAST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRY_CAST, 0); } public KW_TYPE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TYPE, 0); } public KW_UNARCHIVE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNARCHIVE, 0); } public KW_UNBOUNDED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNBOUNDED, 0); } public KW_UNCACHE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNCACHE, 0); } public KW_UNLOCK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNLOCK, 0); } public KW_UNPIVOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNPIVOT, 0); } public KW_UNSET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNSET, 0); } public KW_UPDATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UPDATE, 0); } public KW_USE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_USE, 0); } public KW_VALUES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VALUES, 0); } public KW_VARCHAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VARCHAR, 0); } public KW_VAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VAR, 0); } public KW_VARIABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VARIABLE, 0); } public KW_VERSION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VERSION, 0); } public KW_VIEW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VIEW, 0); } public KW_VIEWS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VIEWS, 0); } public KW_VOID(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VOID, 0); } public KW_WEEK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WEEK, 0); } public KW_WEEKS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WEEKS, 0); } public KW_WINDOW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WINDOW, 0); } public KW_YEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_YEAR, 0); } public KW_YEARS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_YEARS, 0); } public KW_ZONE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ZONE, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_ansiNonReserved; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterAnsiNonReserved) { listener.enterAnsiNonReserved(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitAnsiNonReserved) { listener.exitAnsiNonReserved(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitAnsiNonReserved) { return visitor.visitAnsiNonReserved(this); } else { return visitor.visitChildren(this); } } } export class StrictNonReservedContext extends ParserRuleContext { public KW_ANTI(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANTI, 0); } public KW_CROSS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CROSS, 0); } public KW_EXCEPT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXCEPT, 0); } public KW_FULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FULL, 0); } public KW_INNER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INNER, 0); } public KW_INTERSECT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTERSECT, 0); } public KW_JOIN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_JOIN, 0); } public KW_LATERAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LATERAL, 0); } public KW_LEFT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LEFT, 0); } public KW_NATURAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NATURAL, 0); } public KW_ON(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ON, 0); } public KW_RIGHT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RIGHT, 0); } public KW_SEMI(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SEMI, 0); } public KW_SETMINUS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SETMINUS, 0); } public KW_UNION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNION, 0); } public KW_USING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_USING, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_strictNonReserved; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterStrictNonReserved) { listener.enterStrictNonReserved(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitStrictNonReserved) { listener.exitStrictNonReserved(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitStrictNonReserved) { return visitor.visitStrictNonReserved(this); } else { return visitor.visitChildren(this); } } } export class NonReservedContext extends ParserRuleContext { public KW_ADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ADD, 0); } public KW_AFTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AFTER, 0); } public KW_ALL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALL, 0); } public KW_ALTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALTER, 0); } public KW_ALWAYS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ALWAYS, 0); } public KW_ANALYZE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANALYZE, 0); } public KW_AND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AND, 0); } public KW_ANY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANY, 0); } public KW_ANY_VALUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ANY_VALUE, 0); } public KW_ARCHIVE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ARCHIVE, 0); } public KW_ARRAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ARRAY, 0); } public KW_AS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AS, 0); } public KW_ASC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ASC, 0); } public KW_AT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AT, 0); } public KW_AUTHORIZATION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_AUTHORIZATION, 0); } public KW_BETWEEN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BETWEEN, 0); } public KW_BIGINT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BIGINT, 0); } public KW_BINARY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BINARY, 0); } public KW_BINARY_HEX(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BINARY_HEX, 0); } public KW_BOOLEAN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BOOLEAN, 0); } public KW_BOTH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BOTH, 0); } public KW_BUCKET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BUCKET, 0); } public KW_BUCKETS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BUCKETS, 0); } public KW_BY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BY, 0); } public KW_BYTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_BYTE, 0); } public KW_CACHE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CACHE, 0); } public KW_CASCADE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CASCADE, 0); } public KW_CASE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CASE, 0); } public KW_CAST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CAST, 0); } public KW_CATALOG(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CATALOG, 0); } public KW_CATALOGS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CATALOGS, 0); } public KW_CHANGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CHANGE, 0); } public KW_CHAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CHAR, 0); } public KW_CHARACTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CHARACTER, 0); } public KW_CHECK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CHECK, 0); } public KW_CLEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CLEAR, 0); } public KW_CLUSTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CLUSTER, 0); } public KW_CLUSTERED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CLUSTERED, 0); } public KW_CODEGEN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CODEGEN, 0); } public KW_COLLATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COLLATE, 0); } public KW_COLLECTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COLLECTION, 0); } public KW_COLUMN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COLUMN, 0); } public KW_COLUMNS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COLUMNS, 0); } public KW_COMMENT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMMENT, 0); } public KW_COMMIT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMMIT, 0); } public KW_COMPACT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMPACT, 0); } public KW_COMPACTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMPACTIONS, 0); } public KW_COMPUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COMPUTE, 0); } public KW_CONCATENATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CONCATENATE, 0); } public KW_CONSTRAINT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CONSTRAINT, 0); } public KW_COST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_COST, 0); } public KW_CREATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CREATE, 0); } public KW_CUBE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CUBE, 0); } public KW_CURRENT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT, 0); } public KW_CURRENT_DATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT_DATE, 0); } public KW_CURRENT_TIME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT_TIME, 0); } public KW_CURRENT_TIMESTAMP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT_TIMESTAMP, 0); } public KW_CURRENT_USER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_CURRENT_USER, 0); } public KW_DATA(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATA, 0); } public KW_DATABASE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATABASE, 0); } public KW_DATABASES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATABASES, 0); } public KW_DATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATE, 0); } public KW_DATEADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATEADD, 0); } public KW_DATE_ADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATE_ADD, 0); } public KW_DATEDIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATEDIFF, 0); } public KW_DATE_DIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DATE_DIFF, 0); } public KW_DAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAY, 0); } public KW_DAYS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAYS, 0); } public KW_DAYOFYEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DAYOFYEAR, 0); } public KW_DBPROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DBPROPERTIES, 0); } public KW_DEC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEC, 0); } public KW_DECIMAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DECIMAL, 0); } public KW_DECLARE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DECLARE, 0); } public KW_DEFAULT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEFAULT, 0); } public KW_DEFINED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DEFINED, 0); } public KW_DELETE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DELETE, 0); } public KW_DELIMITED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DELIMITED, 0); } public KW_DESC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DESC, 0); } public KW_DESCRIBE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DESCRIBE, 0); } public KW_DFS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DFS, 0); } public KW_DIRECTORIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIRECTORIES, 0); } public KW_DIRECTORY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIRECTORY, 0); } public KW_DISTINCT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DISTINCT, 0); } public KW_DISTRIBUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DISTRIBUTE, 0); } public KW_DIV(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DIV, 0); } public KW_DOUBLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DOUBLE, 0); } public KW_DROP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_DROP, 0); } public KW_ELSE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ELSE, 0); } public KW_END(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_END, 0); } public KW_ESCAPE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ESCAPE, 0); } public KW_ESCAPED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ESCAPED, 0); } public KW_EXCHANGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXCHANGE, 0); } public KW_EXCLUDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXCLUDE, 0); } public KW_EXISTS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXISTS, 0); } public KW_EXPLAIN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXPLAIN, 0); } public KW_EXPORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXPORT, 0); } public KW_EXTENDED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXTENDED, 0); } public KW_EXTERNAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXTERNAL, 0); } public KW_EXTRACT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_EXTRACT, 0); } public KW_FALSE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FALSE, 0); } public KW_FETCH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FETCH, 0); } public KW_FILTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FILTER, 0); } public KW_FIELDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FIELDS, 0); } public KW_FILEFORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FILEFORMAT, 0); } public KW_FIRST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FIRST, 0); } public KW_FLOAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FLOAT, 0); } public KW_FOLLOWING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FOLLOWING, 0); } public KW_FOR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FOR, 0); } public KW_FOREIGN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FOREIGN, 0); } public KW_FORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FORMAT, 0); } public KW_FORMATTED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FORMATTED, 0); } public KW_FROM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FROM, 0); } public KW_FUNCTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FUNCTION, 0); } public KW_FUNCTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_FUNCTIONS, 0); } public KW_GENERATED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GENERATED, 0); } public KW_GLOBAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GLOBAL, 0); } public KW_GRANT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GRANT, 0); } public KW_GROUP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GROUP, 0); } public KW_GROUPING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_GROUPING, 0); } public KW_HAVING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_HAVING, 0); } public KW_HOUR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_HOUR, 0); } public KW_HOURS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_HOURS, 0); } public KW_IDENTIFIER_KW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IDENTIFIER_KW, 0); } public KW_IF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IF, 0); } public KW_IGNORE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IGNORE, 0); } public KW_IMPORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IMPORT, 0); } public KW_IN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IN, 0); } public KW_INCLUDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INCLUDE, 0); } public KW_INDEX(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INDEX, 0); } public KW_INDEXES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INDEXES, 0); } public KW_INPATH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INPATH, 0); } public KW_INPUTFORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INPUTFORMAT, 0); } public KW_INSERT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INSERT, 0); } public KW_INT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INT, 0); } public KW_INTEGER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTEGER, 0); } public KW_INTERVAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTERVAL, 0); } public KW_INTO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_INTO, 0); } public KW_IS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_IS, 0); } public KW_ITEMS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ITEMS, 0); } public KW_KEYS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_KEYS, 0); } public KW_LAST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LAST, 0); } public KW_LAZY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LAZY, 0); } public KW_LEADING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LEADING, 0); } public KW_LIKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LIKE, 0); } public KW_LONG(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LONG, 0); } public KW_ILIKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ILIKE, 0); } public KW_LIMIT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LIMIT, 0); } public KW_LINES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LINES, 0); } public KW_LIST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LIST, 0); } public KW_LOAD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOAD, 0); } public KW_LOCAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCAL, 0); } public KW_LOCATION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCATION, 0); } public KW_LOCK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCK, 0); } public KW_LOCKS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOCKS, 0); } public KW_LOGICAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_LOGICAL, 0); } public KW_MACRO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MACRO, 0); } public KW_MAP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MAP, 0); } public KW_MATCHED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MATCHED, 0); } public KW_MERGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MERGE, 0); } public KW_MICROSECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MICROSECOND, 0); } public KW_MICROSECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MICROSECONDS, 0); } public KW_MILLISECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MILLISECOND, 0); } public KW_MILLISECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MILLISECONDS, 0); } public KW_MINUTE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MINUTE, 0); } public KW_MINUTES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MINUTES, 0); } public KW_MONTH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MONTH, 0); } public KW_MONTHS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MONTHS, 0); } public KW_MSCK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_MSCK, 0); } public KW_NAME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NAME, 0); } public KW_NAMESPACE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NAMESPACE, 0); } public KW_NAMESPACES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NAMESPACES, 0); } public KW_NANOSECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NANOSECOND, 0); } public KW_NANOSECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NANOSECONDS, 0); } public KW_NO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NO, 0); } public KW_NOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NOT, 0); } public KW_NULL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULL, 0); } public KW_NULLS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NULLS, 0); } public KW_NUMERIC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_NUMERIC, 0); } public KW_OF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OF, 0); } public KW_OFFSET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OFFSET, 0); } public KW_ONLY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ONLY, 0); } public KW_OPTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OPTION, 0); } public KW_OPTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OPTIONS, 0); } public KW_OR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OR, 0); } public KW_ORDER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ORDER, 0); } public KW_OUT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OUT, 0); } public KW_OUTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OUTER, 0); } public KW_OUTPUTFORMAT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OUTPUTFORMAT, 0); } public KW_OVER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVER, 0); } public KW_OVERLAPS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVERLAPS, 0); } public KW_OVERLAY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVERLAY, 0); } public KW_OVERWRITE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_OVERWRITE, 0); } public KW_PARTITION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PARTITION, 0); } public KW_PARTITIONED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PARTITIONED, 0); } public KW_PARTITIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PARTITIONS, 0); } public KW_PERCENTILE_CONT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PERCENTILE_CONT, 0); } public KW_PERCENTILE_DISC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PERCENTILE_DISC, 0); } public KW_PERCENTLIT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PERCENTLIT, 0); } public KW_PIVOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PIVOT, 0); } public KW_PLACING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PLACING, 0); } public KW_POSITION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_POSITION, 0); } public KW_PRECEDING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PRECEDING, 0); } public KW_PRIMARY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PRIMARY, 0); } public KW_PRINCIPALS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PRINCIPALS, 0); } public KW_PROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PROPERTIES, 0); } public KW_PURGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_PURGE, 0); } public KW_QUARTER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_QUARTER, 0); } public KW_QUERY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_QUERY, 0); } public KW_RANGE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RANGE, 0); } public KW_REAL(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REAL, 0); } public KW_RECORDREADER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RECORDREADER, 0); } public KW_RECORDWRITER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RECORDWRITER, 0); } public KW_RECOVER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RECOVER, 0); } public KW_REDUCE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REDUCE, 0); } public KW_REFERENCES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REFERENCES, 0); } public KW_REFRESH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REFRESH, 0); } public KW_RENAME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RENAME, 0); } public KW_REPAIR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPAIR, 0); } public KW_REPEATABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPEATABLE, 0); } public KW_REPLACE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REPLACE, 0); } public KW_RESET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RESET, 0); } public KW_RESPECT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RESPECT, 0); } public KW_RESTRICT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RESTRICT, 0); } public KW_REVOKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REVOKE, 0); } public KW_RLIKE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_RLIKE, 0); } public KW_REGEXP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_REGEXP, 0); } public KW_ROLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLE, 0); } public KW_ROLES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLES, 0); } public KW_ROLLBACK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLLBACK, 0); } public KW_ROLLUP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROLLUP, 0); } public KW_ROW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROW, 0); } public KW_ROWS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ROWS, 0); } public KW_SCHEMA(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SCHEMA, 0); } public KW_SCHEMAS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SCHEMAS, 0); } public KW_SECOND(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SECOND, 0); } public KW_SECONDS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SECONDS, 0); } public KW_SELECT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SELECT, 0); } public KW_SEPARATED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SEPARATED, 0); } public KW_SERDE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SERDE, 0); } public KW_SERDEPROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SERDEPROPERTIES, 0); } public KW_SESSION_USER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SESSION_USER, 0); } public KW_SET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SET, 0); } public KW_SETS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SETS, 0); } public KW_SHORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SHORT, 0); } public KW_SHOW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SHOW, 0); } public KW_SINGLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SINGLE, 0); } public KW_SKEWED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SKEWED, 0); } public KW_SMALLINT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SMALLINT, 0); } public KW_SOME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SOME, 0); } public KW_SORT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SORT, 0); } public KW_SORTED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SORTED, 0); } public KW_SOURCE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SOURCE, 0); } public KW_START(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_START, 0); } public KW_STATISTICS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STATISTICS, 0); } public KW_STORED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STORED, 0); } public KW_STRATIFY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STRATIFY, 0); } public KW_STRING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STRING, 0); } public KW_STRUCT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_STRUCT, 0); } public KW_SUBSTR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SUBSTR, 0); } public KW_SUBSTRING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SUBSTRING, 0); } public KW_SYNC(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYNC, 0); } public KW_SYSTEM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYSTEM, 0); } public KW_SYSTEM_TIME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYSTEM_TIME, 0); } public KW_SYSTEM_VERSION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_SYSTEM_VERSION, 0); } public KW_TABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TABLE, 0); } public KW_TABLES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TABLES, 0); } public KW_TABLESAMPLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TABLESAMPLE, 0); } public KW_TARGET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TARGET, 0); } public KW_TBLPROPERTIES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TBLPROPERTIES, 0); } public KW_TEMPORARY(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TEMPORARY, 0); } public KW_TERMINATED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TERMINATED, 0); } public KW_THEN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_THEN, 0); } public KW_TIME(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIME, 0); } public KW_TIMEDIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMEDIFF, 0); } public KW_TIMESTAMP(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP, 0); } public KW_TIMESTAMP_LTZ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP_LTZ, 0); } public KW_TIMESTAMP_NTZ(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMP_NTZ, 0); } public KW_TIMESTAMPADD(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMPADD, 0); } public KW_TIMESTAMPDIFF(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TIMESTAMPDIFF, 0); } public KW_TINYINT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TINYINT, 0); } public KW_TO(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TO, 0); } public KW_TOUCH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TOUCH, 0); } public KW_TRAILING(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRAILING, 0); } public KW_TRANSACTION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRANSACTION, 0); } public KW_TRANSACTIONS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRANSACTIONS, 0); } public KW_TRANSFORM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRANSFORM, 0); } public KW_TRIM(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRIM, 0); } public KW_TRUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRUE, 0); } public KW_TRUNCATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRUNCATE, 0); } public KW_TRY_CAST(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TRY_CAST, 0); } public KW_TYPE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_TYPE, 0); } public KW_UNARCHIVE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNARCHIVE, 0); } public KW_UNBOUNDED(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNBOUNDED, 0); } public KW_UNCACHE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNCACHE, 0); } public KW_UNIQUE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNIQUE, 0); } public KW_UNKNOWN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNKNOWN, 0); } public KW_UNLOCK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNLOCK, 0); } public KW_UNPIVOT(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNPIVOT, 0); } public KW_UNSET(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UNSET, 0); } public KW_UPDATE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_UPDATE, 0); } public KW_USE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_USE, 0); } public KW_USER(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_USER, 0); } public KW_VALUES(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VALUES, 0); } public KW_VARCHAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VARCHAR, 0); } public KW_VAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VAR, 0); } public KW_VARIABLE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VARIABLE, 0); } public KW_VERSION(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VERSION, 0); } public KW_VIEW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VIEW, 0); } public KW_VIEWS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VIEWS, 0); } public KW_VOID(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_VOID, 0); } public KW_WEEK(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WEEK, 0); } public KW_WEEKS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WEEKS, 0); } public KW_WHEN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WHEN, 0); } public KW_WHERE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WHERE, 0); } public KW_WINDOW(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WINDOW, 0); } public KW_WITH(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WITH, 0); } public KW_WITHIN(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_WITHIN, 0); } public KW_YEAR(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_YEAR, 0); } public KW_YEARS(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_YEARS, 0); } public KW_ZONE(): TerminalNode | undefined { return this.tryGetToken(SparkSqlParser.KW_ZONE, 0); } constructor(parent: ParserRuleContext | undefined, invokingState: number) { super(parent, invokingState); } // @Override public get ruleIndex(): number { return SparkSqlParser.RULE_nonReserved; } // @Override public enterRule(listener: SparkSqlParserListener): void { if (listener.enterNonReserved) { listener.enterNonReserved(this); } } // @Override public exitRule(listener: SparkSqlParserListener): void { if (listener.exitNonReserved) { listener.exitNonReserved(this); } } // @Override public accept(visitor: SparkSqlParserVisitor): Result { if (visitor.visitNonReserved) { return visitor.visitNonReserved(this); } else { return visitor.visitChildren(this); } } }