SQL: add catalog and type arguments to SYS TABLES (elastic/x-pack-elasticsearch#3920)

Extend the SYS TABLES command to allow filtering by catalog and types
Add creation of EnumSet inside node tests
Handle EnumSet inside test for replaceChildren

Original commit: elastic/x-pack-elasticsearch@407ce7b006
This commit is contained in:
Costin Leau 2018-02-15 22:07:51 +02:00 committed by GitHub
parent 844c485e0d
commit ae8152b55b
18 changed files with 1651 additions and 1402 deletions

View File

@ -701,8 +701,28 @@ class JdbcDatabaseMetaData implements DatabaseMetaData, JdbcWrapper {
@Override
public ResultSet getTables(String catalog, String schemaPattern, String tableNamePattern, String[] types) throws SQLException {
PreparedStatement ps = con.prepareStatement("SYS TABLES LIKE ?");
ps.setString(1, tableNamePattern != null ? tableNamePattern.trim() : "%");
String statement = "SYS TABLES CATALOG LIKE ? LIKE ?";
if (types != null && types.length > 0) {
statement += " TYPE ?";
if (types.length > 1) {
for (int i = 1; i < types.length; i++) {
statement += ", ?";
}
}
}
PreparedStatement ps = con.prepareStatement(statement);
ps.setString(1, catalog != null ? catalog.trim() : "%");
ps.setString(2, tableNamePattern != null ? tableNamePattern.trim() : "%");
if (types != null && types.length > 0) {
for (int i = 0; i < types.length; i++) {
ps.setString(3 + i, types[i]);
}
}
return ps.executeQuery();
}
@ -739,7 +759,7 @@ class JdbcDatabaseMetaData implements DatabaseMetaData, JdbcWrapper {
@Override
public ResultSet getColumns(String catalog, String schemaPattern, String tableNamePattern, String columnNamePattern)
throws SQLException {
PreparedStatement ps = con.prepareStatement("SYS COLUMNS TABLES LIKE ? LIKE ?");
PreparedStatement ps = con.prepareStatement("SYS COLUMNS TABLE LIKE ? LIKE ?");
ps.setString(1, tableNamePattern != null ? tableNamePattern.trim() : "%");
ps.setString(2, columnNamePattern != null ? columnNamePattern.trim() : "%");
return ps.executeQuery();

View File

@ -55,9 +55,11 @@ statement
| (DESCRIBE | DESC) tableIdentifier #showColumns
| SHOW FUNCTIONS (LIKE? pattern)? #showFunctions
| SHOW SCHEMAS #showSchemas
| SYS CATALOGS #sysCatalogs
| SYS TABLES (LIKE? pattern)? #sysTables
| SYS COLUMNS (TABLES LIKE? indexPattern=pattern)? (LIKE? columnPattern=pattern)? #sysColumns
| SYS TABLES (CATALOG LIKE? clusterPattern=pattern)?
(LIKE? tablePattern=pattern)?
(TYPE STRING (',' STRING)* )? #sysTables
| SYS COLUMNS (TABLE LIKE? indexPattern=pattern)?
(LIKE? columnPattern=pattern)? #sysColumns
| SYS TYPES #sysTypes
| SYS TABLE TYPES #sysTableTypes
;
@ -269,7 +271,7 @@ nonReserved
| QUERY
| RLIKE
| SCHEMAS | SHOW | SYS
| TABLES | TEXT | TYPES
| TABLES | TEXT | TYPE | TYPES
| VERIFY
;
@ -283,8 +285,7 @@ ASC: 'ASC';
BETWEEN: 'BETWEEN';
BY: 'BY';
CAST: 'CAST';
CATALOGS: 'CATALOGS';
COLUMNS: 'COLUMNS';
CATALOG: 'CATALOG';CATALOGS: 'CATALOGS';COLUMNS: 'COLUMNS';
DEBUG: 'DEBUG';
DESC: 'DESC';
DESCRIBE: 'DESCRIBE';
@ -333,6 +334,7 @@ TABLE: 'TABLE';
TABLES: 'TABLES';
TEXT: 'TEXT';
TRUE: 'TRUE';
TYPE: 'TYPE';
TYPES: 'TYPES';
USING: 'USING';
VERIFY: 'VERIFY';

View File

@ -12,87 +12,89 @@ ASC=11
BETWEEN=12
BY=13
CAST=14
CATALOGS=15
COLUMNS=16
DEBUG=17
DESC=18
DESCRIBE=19
DISTINCT=20
ESCAPE=21
EXECUTABLE=22
EXISTS=23
EXPLAIN=24
EXTRACT=25
FALSE=26
FORMAT=27
FROM=28
FULL=29
FUNCTIONS=30
GRAPHVIZ=31
GROUP=32
HAVING=33
IN=34
INNER=35
IS=36
JOIN=37
LEFT=38
LIKE=39
LIMIT=40
MAPPED=41
MATCH=42
NATURAL=43
NOT=44
NULL=45
ON=46
OPTIMIZED=47
OR=48
ORDER=49
OUTER=50
PARSED=51
PHYSICAL=52
PLAN=53
RIGHT=54
RLIKE=55
QUERY=56
SCHEMAS=57
SELECT=58
SHOW=59
SYS=60
TABLE=61
TABLES=62
TEXT=63
TRUE=64
TYPES=65
USING=66
VERIFY=67
WHERE=68
WITH=69
EQ=70
NEQ=71
LT=72
LTE=73
GT=74
GTE=75
PLUS=76
MINUS=77
ASTERISK=78
SLASH=79
PERCENT=80
CONCAT=81
DOT=82
STRING=83
INTEGER_VALUE=84
DECIMAL_VALUE=85
IDENTIFIER=86
DIGIT_IDENTIFIER=87
TABLE_IDENTIFIER=88
QUOTED_IDENTIFIER=89
BACKQUOTED_IDENTIFIER=90
SIMPLE_COMMENT=91
BRACKETED_COMMENT=92
WS=93
UNRECOGNIZED=94
DELIMITER=95
CATALOG=15
CATALOGS=16
COLUMNS=17
DEBUG=18
DESC=19
DESCRIBE=20
DISTINCT=21
ESCAPE=22
EXECUTABLE=23
EXISTS=24
EXPLAIN=25
EXTRACT=26
FALSE=27
FORMAT=28
FROM=29
FULL=30
FUNCTIONS=31
GRAPHVIZ=32
GROUP=33
HAVING=34
IN=35
INNER=36
IS=37
JOIN=38
LEFT=39
LIKE=40
LIMIT=41
MAPPED=42
MATCH=43
NATURAL=44
NOT=45
NULL=46
ON=47
OPTIMIZED=48
OR=49
ORDER=50
OUTER=51
PARSED=52
PHYSICAL=53
PLAN=54
RIGHT=55
RLIKE=56
QUERY=57
SCHEMAS=58
SELECT=59
SHOW=60
SYS=61
TABLE=62
TABLES=63
TEXT=64
TRUE=65
TYPE=66
TYPES=67
USING=68
VERIFY=69
WHERE=70
WITH=71
EQ=72
NEQ=73
LT=74
LTE=75
GT=76
GTE=77
PLUS=78
MINUS=79
ASTERISK=80
SLASH=81
PERCENT=82
CONCAT=83
DOT=84
STRING=85
INTEGER_VALUE=86
DECIMAL_VALUE=87
IDENTIFIER=88
DIGIT_IDENTIFIER=89
TABLE_IDENTIFIER=90
QUOTED_IDENTIFIER=91
BACKQUOTED_IDENTIFIER=92
SIMPLE_COMMENT=93
BRACKETED_COMMENT=94
WS=95
UNRECOGNIZED=96
DELIMITER=97
'('=1
')'=2
','=3
@ -107,70 +109,72 @@ DELIMITER=95
'BETWEEN'=12
'BY'=13
'CAST'=14
'CATALOGS'=15
'COLUMNS'=16
'DEBUG'=17
'DESC'=18
'DESCRIBE'=19
'DISTINCT'=20
'ESCAPE'=21
'EXECUTABLE'=22
'EXISTS'=23
'EXPLAIN'=24
'EXTRACT'=25
'FALSE'=26
'FORMAT'=27
'FROM'=28
'FULL'=29
'FUNCTIONS'=30
'GRAPHVIZ'=31
'GROUP'=32
'HAVING'=33
'IN'=34
'INNER'=35
'IS'=36
'JOIN'=37
'LEFT'=38
'LIKE'=39
'LIMIT'=40
'MAPPED'=41
'MATCH'=42
'NATURAL'=43
'NOT'=44
'NULL'=45
'ON'=46
'OPTIMIZED'=47
'OR'=48
'ORDER'=49
'OUTER'=50
'PARSED'=51
'PHYSICAL'=52
'PLAN'=53
'RIGHT'=54
'RLIKE'=55
'QUERY'=56
'SCHEMAS'=57
'SELECT'=58
'SHOW'=59
'SYS'=60
'TABLE'=61
'TABLES'=62
'TEXT'=63
'TRUE'=64
'TYPES'=65
'USING'=66
'VERIFY'=67
'WHERE'=68
'WITH'=69
'='=70
'<'=72
'<='=73
'>'=74
'>='=75
'+'=76
'-'=77
'*'=78
'/'=79
'%'=80
'||'=81
'.'=82
'CATALOG'=15
'CATALOGS'=16
'COLUMNS'=17
'DEBUG'=18
'DESC'=19
'DESCRIBE'=20
'DISTINCT'=21
'ESCAPE'=22
'EXECUTABLE'=23
'EXISTS'=24
'EXPLAIN'=25
'EXTRACT'=26
'FALSE'=27
'FORMAT'=28
'FROM'=29
'FULL'=30
'FUNCTIONS'=31
'GRAPHVIZ'=32
'GROUP'=33
'HAVING'=34
'IN'=35
'INNER'=36
'IS'=37
'JOIN'=38
'LEFT'=39
'LIKE'=40
'LIMIT'=41
'MAPPED'=42
'MATCH'=43
'NATURAL'=44
'NOT'=45
'NULL'=46
'ON'=47
'OPTIMIZED'=48
'OR'=49
'ORDER'=50
'OUTER'=51
'PARSED'=52
'PHYSICAL'=53
'PLAN'=54
'RIGHT'=55
'RLIKE'=56
'QUERY'=57
'SCHEMAS'=58
'SELECT'=59
'SHOW'=60
'SYS'=61
'TABLE'=62
'TABLES'=63
'TEXT'=64
'TRUE'=65
'TYPE'=66
'TYPES'=67
'USING'=68
'VERIFY'=69
'WHERE'=70
'WITH'=71
'='=72
'<'=74
'<='=75
'>'=76
'>='=77
'+'=78
'-'=79
'*'=80
'/'=81
'%'=82
'||'=83
'.'=84

View File

@ -12,86 +12,88 @@ ASC=11
BETWEEN=12
BY=13
CAST=14
CATALOGS=15
COLUMNS=16
DEBUG=17
DESC=18
DESCRIBE=19
DISTINCT=20
ESCAPE=21
EXECUTABLE=22
EXISTS=23
EXPLAIN=24
EXTRACT=25
FALSE=26
FORMAT=27
FROM=28
FULL=29
FUNCTIONS=30
GRAPHVIZ=31
GROUP=32
HAVING=33
IN=34
INNER=35
IS=36
JOIN=37
LEFT=38
LIKE=39
LIMIT=40
MAPPED=41
MATCH=42
NATURAL=43
NOT=44
NULL=45
ON=46
OPTIMIZED=47
OR=48
ORDER=49
OUTER=50
PARSED=51
PHYSICAL=52
PLAN=53
RIGHT=54
RLIKE=55
QUERY=56
SCHEMAS=57
SELECT=58
SHOW=59
SYS=60
TABLE=61
TABLES=62
TEXT=63
TRUE=64
TYPES=65
USING=66
VERIFY=67
WHERE=68
WITH=69
EQ=70
NEQ=71
LT=72
LTE=73
GT=74
GTE=75
PLUS=76
MINUS=77
ASTERISK=78
SLASH=79
PERCENT=80
CONCAT=81
DOT=82
STRING=83
INTEGER_VALUE=84
DECIMAL_VALUE=85
IDENTIFIER=86
DIGIT_IDENTIFIER=87
TABLE_IDENTIFIER=88
QUOTED_IDENTIFIER=89
BACKQUOTED_IDENTIFIER=90
SIMPLE_COMMENT=91
BRACKETED_COMMENT=92
WS=93
UNRECOGNIZED=94
CATALOG=15
CATALOGS=16
COLUMNS=17
DEBUG=18
DESC=19
DESCRIBE=20
DISTINCT=21
ESCAPE=22
EXECUTABLE=23
EXISTS=24
EXPLAIN=25
EXTRACT=26
FALSE=27
FORMAT=28
FROM=29
FULL=30
FUNCTIONS=31
GRAPHVIZ=32
GROUP=33
HAVING=34
IN=35
INNER=36
IS=37
JOIN=38
LEFT=39
LIKE=40
LIMIT=41
MAPPED=42
MATCH=43
NATURAL=44
NOT=45
NULL=46
ON=47
OPTIMIZED=48
OR=49
ORDER=50
OUTER=51
PARSED=52
PHYSICAL=53
PLAN=54
RIGHT=55
RLIKE=56
QUERY=57
SCHEMAS=58
SELECT=59
SHOW=60
SYS=61
TABLE=62
TABLES=63
TEXT=64
TRUE=65
TYPE=66
TYPES=67
USING=68
VERIFY=69
WHERE=70
WITH=71
EQ=72
NEQ=73
LT=74
LTE=75
GT=76
GTE=77
PLUS=78
MINUS=79
ASTERISK=80
SLASH=81
PERCENT=82
CONCAT=83
DOT=84
STRING=85
INTEGER_VALUE=86
DECIMAL_VALUE=87
IDENTIFIER=88
DIGIT_IDENTIFIER=89
TABLE_IDENTIFIER=90
QUOTED_IDENTIFIER=91
BACKQUOTED_IDENTIFIER=92
SIMPLE_COMMENT=93
BRACKETED_COMMENT=94
WS=95
UNRECOGNIZED=96
'('=1
')'=2
','=3
@ -106,70 +108,72 @@ UNRECOGNIZED=94
'BETWEEN'=12
'BY'=13
'CAST'=14
'CATALOGS'=15
'COLUMNS'=16
'DEBUG'=17
'DESC'=18
'DESCRIBE'=19
'DISTINCT'=20
'ESCAPE'=21
'EXECUTABLE'=22
'EXISTS'=23
'EXPLAIN'=24
'EXTRACT'=25
'FALSE'=26
'FORMAT'=27
'FROM'=28
'FULL'=29
'FUNCTIONS'=30
'GRAPHVIZ'=31
'GROUP'=32
'HAVING'=33
'IN'=34
'INNER'=35
'IS'=36
'JOIN'=37
'LEFT'=38
'LIKE'=39
'LIMIT'=40
'MAPPED'=41
'MATCH'=42
'NATURAL'=43
'NOT'=44
'NULL'=45
'ON'=46
'OPTIMIZED'=47
'OR'=48
'ORDER'=49
'OUTER'=50
'PARSED'=51
'PHYSICAL'=52
'PLAN'=53
'RIGHT'=54
'RLIKE'=55
'QUERY'=56
'SCHEMAS'=57
'SELECT'=58
'SHOW'=59
'SYS'=60
'TABLE'=61
'TABLES'=62
'TEXT'=63
'TRUE'=64
'TYPES'=65
'USING'=66
'VERIFY'=67
'WHERE'=68
'WITH'=69
'='=70
'<'=72
'<='=73
'>'=74
'>='=75
'+'=76
'-'=77
'*'=78
'/'=79
'%'=80
'||'=81
'.'=82
'CATALOG'=15
'CATALOGS'=16
'COLUMNS'=17
'DEBUG'=18
'DESC'=19
'DESCRIBE'=20
'DISTINCT'=21
'ESCAPE'=22
'EXECUTABLE'=23
'EXISTS'=24
'EXPLAIN'=25
'EXTRACT'=26
'FALSE'=27
'FORMAT'=28
'FROM'=29
'FULL'=30
'FUNCTIONS'=31
'GRAPHVIZ'=32
'GROUP'=33
'HAVING'=34
'IN'=35
'INNER'=36
'IS'=37
'JOIN'=38
'LEFT'=39
'LIKE'=40
'LIMIT'=41
'MAPPED'=42
'MATCH'=43
'NATURAL'=44
'NOT'=45
'NULL'=46
'ON'=47
'OPTIMIZED'=48
'OR'=49
'ORDER'=50
'OUTER'=51
'PARSED'=52
'PHYSICAL'=53
'PLAN'=54
'RIGHT'=55
'RLIKE'=56
'QUERY'=57
'SCHEMAS'=58
'SELECT'=59
'SHOW'=60
'SYS'=61
'TABLE'=62
'TABLES'=63
'TEXT'=64
'TRUE'=65
'TYPE'=66
'TYPES'=67
'USING'=68
'VERIFY'=69
'WHERE'=70
'WITH'=71
'='=72
'<'=74
'<='=75
'>'=76
'>='=77
'+'=78
'-'=79
'*'=80
'/'=81
'%'=82
'||'=83
'.'=84

View File

@ -14,6 +14,7 @@ import org.elasticsearch.action.admin.indices.alias.get.GetAliasesRequest;
import org.elasticsearch.action.admin.indices.alias.get.GetAliasesResponse;
import org.elasticsearch.action.admin.indices.get.GetIndexRequest;
import org.elasticsearch.action.admin.indices.get.GetIndexRequest.Feature;
import org.elasticsearch.action.admin.indices.get.GetIndexResponse;
import org.elasticsearch.action.support.IndicesOptions;
import org.elasticsearch.client.Client;
import org.elasticsearch.cluster.metadata.AliasMetaData;
@ -22,11 +23,14 @@ import org.elasticsearch.common.collect.ImmutableOpenMap;
import org.elasticsearch.index.IndexNotFoundException;
import org.elasticsearch.xpack.sql.type.EsField;
import org.elasticsearch.xpack.sql.type.Types;
import org.elasticsearch.xpack.sql.util.CollectionUtils;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.EnumSet;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.Objects;
import java.util.Set;
@ -51,13 +55,25 @@ public class IndexResolver {
public String toSql() {
return toSql;
}
public static IndexType from(String name) {
if (name != null) {
name = name.toUpperCase(Locale.ROOT);
for (IndexType type : IndexType.values()) {
if (type.toSql.equals(name)) {
return type;
}
}
}
return null;
}
}
public static class IndexInfo {
private final String name;
private final IndexType type;
private IndexInfo(String name, IndexType type) {
public IndexInfo(String name, IndexType type) {
this.name = name;
this.type = type;
}
@ -113,64 +129,83 @@ public class IndexResolver {
* Resolves only the names, differentiating between indices and aliases.
* This method is required since the other methods rely on mapping which is tied to an index (not an alias).
*/
public void resolveNames(String indexWildcard, String javaRegex, ActionListener<Set<IndexInfo>> listener) {
// first get aliases
GetAliasesRequest aliasRequest = new GetAliasesRequest()
.local(true)
.aliases(indexWildcard)
.indicesOptions(IndicesOptions.lenientExpandOpen());
public void resolveNames(String indexWildcard, String javaRegex, EnumSet<IndexType> types, ActionListener<Set<IndexInfo>> listener) {
client.admin().indices().getAliases(aliasRequest, ActionListener.wrap(aliases ->
resolveIndices(indexWildcard, javaRegex, aliases, listener),
ex -> {
// with security, two exception can be thrown:
// INFE - if no alias matches
// security exception is the user cannot access aliases
// first get aliases (if specified)
boolean retrieveAliases = CollectionUtils.isEmpty(types) || types.contains(IndexType.ALIAS);
boolean retrieveIndices = CollectionUtils.isEmpty(types) || types.contains(IndexType.INDEX);
// in both cases, that is allowed and we continue with the indices request
if (ex instanceof IndexNotFoundException || ex instanceof ElasticsearchSecurityException) {
resolveIndices(indexWildcard, javaRegex, null, listener);
} else {
listener.onFailure(ex);
}
}));
if (retrieveAliases) {
GetAliasesRequest aliasRequest = new GetAliasesRequest()
.local(true)
.aliases(indexWildcard)
.indicesOptions(IndicesOptions.lenientExpandOpen());
client.admin().indices().getAliases(aliasRequest, ActionListener.wrap(aliases ->
resolveIndices(indexWildcard, javaRegex, aliases, retrieveIndices, listener),
ex -> {
// with security, two exception can be thrown:
// INFE - if no alias matches
// security exception is the user cannot access aliases
// in both cases, that is allowed and we continue with the indices request
if (ex instanceof IndexNotFoundException || ex instanceof ElasticsearchSecurityException) {
resolveIndices(indexWildcard, javaRegex, null, retrieveIndices, listener);
} else {
listener.onFailure(ex);
}
}));
} else {
resolveIndices(indexWildcard, javaRegex, null, retrieveIndices, listener);
}
}
private void resolveIndices(String indexWildcard, String javaRegex, GetAliasesResponse aliases,
private void resolveIndices(String indexWildcard, String javaRegex, GetAliasesResponse aliases,
boolean retrieveIndices, ActionListener<Set<IndexInfo>> listener) {
if (retrieveIndices) {
GetIndexRequest indexRequest = new GetIndexRequest()
.local(true)
.indices(indexWildcard)
.indicesOptions(IndicesOptions.lenientExpandOpen());
client.admin().indices().getIndex(indexRequest,
ActionListener.wrap(indices -> filterResults(indexWildcard, javaRegex, aliases, indices, listener),
listener::onFailure));
} else {
filterResults(indexWildcard, javaRegex, aliases, null, listener);
}
}
private void filterResults(String indexWildcard, String javaRegex, GetAliasesResponse aliases, GetIndexResponse indices,
ActionListener<Set<IndexInfo>> listener) {
GetIndexRequest indexRequest = new GetIndexRequest()
.local(true)
.indices(indexWildcard)
.indicesOptions(IndicesOptions.lenientExpandOpen());
// since the index name does not support ?, filter the results manually
Pattern pattern = javaRegex != null ? Pattern.compile(javaRegex) : null;
client.admin().indices().getIndex(indexRequest, ActionListener.wrap(indices -> {
String[] indicesNames = indices.indices();
// since the index name does not support ?, filter the results manually
Pattern pattern = javaRegex != null ? Pattern.compile(javaRegex) : null;
Set<IndexInfo> result = new TreeSet<>(Comparator.comparing(IndexInfo::name));
// unpack aliases (if present)
if (aliases != null) {
for (ObjectCursor<List<AliasMetaData>> cursor : aliases.getAliases().values()) {
for (AliasMetaData amd : cursor.value) {
String alias = amd.alias();
if (alias != null && (pattern == null || pattern.matcher(alias).matches())) {
result.add(new IndexInfo(alias, IndexType.ALIAS));
}
Set<IndexInfo> result = new TreeSet<>(Comparator.comparing(IndexInfo::name));
// filter aliases (if present)
if (aliases != null) {
for (ObjectCursor<List<AliasMetaData>> cursor : aliases.getAliases().values()) {
for (AliasMetaData amd : cursor.value) {
String alias = amd.alias();
if (alias != null && (pattern == null || pattern.matcher(alias).matches())) {
result.add(new IndexInfo(alias, IndexType.ALIAS));
}
}
}
if (indicesNames != null) {
for (String indexName : indicesNames) {
if (pattern == null || pattern.matcher(indexName).matches()) {
result.add(new IndexInfo(indexName, IndexType.INDEX));
}
}
// filter indices (if present)
String[] indicesNames = indices != null ? indices.indices() : null;
if (indicesNames != null) {
for (String indexName : indicesNames) {
if (pattern == null || pattern.matcher(indexName).matches()) {
result.add(new IndexInfo(indexName, IndexType.INDEX));
}
}
listener.onResponse(result);
}, listener::onFailure));
}
listener.onResponse(result);
}

View File

@ -99,6 +99,13 @@ abstract class AbstractBuilder extends SqlBaseBaseVisitor<Object> {
return token == null ? null : unquoteString(token.getText());
}
/**
* Extracts the actual unescaped string (literal) value of a terminal node.
*/
static String string(TerminalNode node) {
return node == null ? null : unquoteString(node.getText());
}
static String unquoteString(String text) {
// remove leading and trailing ' for strings and also eliminate escaped single quotes
return text == null ? null : text.substring(1, text.length() - 1).replace("''", "'");

View File

@ -5,7 +5,9 @@
*/
package org.elasticsearch.xpack.sql.parser;
import org.antlr.v4.runtime.tree.TerminalNode;
import org.elasticsearch.common.Booleans;
import org.elasticsearch.xpack.sql.analysis.index.IndexResolver.IndexType;
import org.elasticsearch.xpack.sql.parser.SqlBaseParser.DebugContext;
import org.elasticsearch.xpack.sql.parser.SqlBaseParser.ExplainContext;
import org.elasticsearch.xpack.sql.parser.SqlBaseParser.ShowColumnsContext;
@ -33,6 +35,9 @@ import org.elasticsearch.xpack.sql.plan.logical.command.sys.SysTypes;
import org.elasticsearch.xpack.sql.tree.Location;
import org.joda.time.DateTimeZone;
import java.util.ArrayList;
import java.util.EnumSet;
import java.util.List;
import java.util.Locale;
abstract class CommandBuilder extends LogicalPlanBuilder {
@ -134,11 +139,21 @@ abstract class CommandBuilder extends LogicalPlanBuilder {
@Override
public Object visitSysCatalogs(SysCatalogsContext ctx) {
return new SysCatalogs(source(ctx));
}
@Override
} @Override
public SysTables visitSysTables(SysTablesContext ctx) {
return new SysTables(source(ctx), visitPattern(ctx.pattern()));
List<IndexType> types = new ArrayList<>();
for (TerminalNode string : ctx.STRING()) {
String value = string(string);
if (value != null) {
IndexType type = IndexType.from(value);
if (type == null) {
throw new ParsingException(source(ctx), "Invalid table type [{}]", value);
}
types.add(type);
}
}
EnumSet<IndexType> set = types.isEmpty() ? null : EnumSet.copyOf(types);
return new SysTables(source(ctx), visitPattern(ctx.clusterPattern), visitPattern(ctx.tablePattern), set);
}
@Override

View File

@ -124,18 +124,6 @@ class SqlBaseBaseListener implements SqlBaseListener {
* <p>The default implementation does nothing.</p>
*/
@Override public void exitShowSchemas(SqlBaseParser.ShowSchemasContext ctx) { }
/**
* {@inheritDoc}
*
* <p>The default implementation does nothing.</p>
*/
@Override public void enterSysCatalogs(SqlBaseParser.SysCatalogsContext ctx) { }
/**
* {@inheritDoc}
*
* <p>The default implementation does nothing.</p>
*/
@Override public void exitSysCatalogs(SqlBaseParser.SysCatalogsContext ctx) { }
/**
* {@inheritDoc}
*

View File

@ -79,13 +79,6 @@ class SqlBaseBaseVisitor<T> extends AbstractParseTreeVisitor<T> implements SqlBa
* {@link #visitChildren} on {@code ctx}.</p>
*/
@Override public T visitShowSchemas(SqlBaseParser.ShowSchemasContext ctx) { return visitChildren(ctx); }
/**
* {@inheritDoc}
*
* <p>The default implementation returns the result of calling
* {@link #visitChildren} on {@code ctx}.</p>
*/
@Override public T visitSysCatalogs(SqlBaseParser.SysCatalogsContext ctx) { return visitChildren(ctx); }
/**
* {@inheritDoc}
*

View File

@ -23,67 +23,68 @@ class SqlBaseLexer extends Lexer {
new PredictionContextCache();
public static final int
T__0=1, T__1=2, T__2=3, T__3=4, ALL=5, ANALYZE=6, ANALYZED=7, AND=8, ANY=9,
AS=10, ASC=11, BETWEEN=12, BY=13, CAST=14, CATALOGS=15, COLUMNS=16, DEBUG=17,
DESC=18, DESCRIBE=19, DISTINCT=20, ESCAPE=21, EXECUTABLE=22, EXISTS=23,
EXPLAIN=24, EXTRACT=25, FALSE=26, FORMAT=27, FROM=28, FULL=29, FUNCTIONS=30,
GRAPHVIZ=31, GROUP=32, HAVING=33, IN=34, INNER=35, IS=36, JOIN=37, LEFT=38,
LIKE=39, LIMIT=40, MAPPED=41, MATCH=42, NATURAL=43, NOT=44, NULL=45, ON=46,
OPTIMIZED=47, OR=48, ORDER=49, OUTER=50, PARSED=51, PHYSICAL=52, PLAN=53,
RIGHT=54, RLIKE=55, QUERY=56, SCHEMAS=57, SELECT=58, SHOW=59, SYS=60,
TABLE=61, TABLES=62, TEXT=63, TRUE=64, TYPES=65, USING=66, VERIFY=67,
WHERE=68, WITH=69, EQ=70, NEQ=71, LT=72, LTE=73, GT=74, GTE=75, PLUS=76,
MINUS=77, ASTERISK=78, SLASH=79, PERCENT=80, CONCAT=81, DOT=82, STRING=83,
INTEGER_VALUE=84, DECIMAL_VALUE=85, IDENTIFIER=86, DIGIT_IDENTIFIER=87,
TABLE_IDENTIFIER=88, QUOTED_IDENTIFIER=89, BACKQUOTED_IDENTIFIER=90, SIMPLE_COMMENT=91,
BRACKETED_COMMENT=92, WS=93, UNRECOGNIZED=94;
AS=10, ASC=11, BETWEEN=12, BY=13, CAST=14, CATALOG=15, CATALOGS=16, COLUMNS=17,
DEBUG=18, DESC=19, DESCRIBE=20, DISTINCT=21, ESCAPE=22, EXECUTABLE=23,
EXISTS=24, EXPLAIN=25, EXTRACT=26, FALSE=27, FORMAT=28, FROM=29, FULL=30,
FUNCTIONS=31, GRAPHVIZ=32, GROUP=33, HAVING=34, IN=35, INNER=36, IS=37,
JOIN=38, LEFT=39, LIKE=40, LIMIT=41, MAPPED=42, MATCH=43, NATURAL=44,
NOT=45, NULL=46, ON=47, OPTIMIZED=48, OR=49, ORDER=50, OUTER=51, PARSED=52,
PHYSICAL=53, PLAN=54, RIGHT=55, RLIKE=56, QUERY=57, SCHEMAS=58, SELECT=59,
SHOW=60, SYS=61, TABLE=62, TABLES=63, TEXT=64, TRUE=65, TYPE=66, TYPES=67,
USING=68, VERIFY=69, WHERE=70, WITH=71, EQ=72, NEQ=73, LT=74, LTE=75,
GT=76, GTE=77, PLUS=78, MINUS=79, ASTERISK=80, SLASH=81, PERCENT=82, CONCAT=83,
DOT=84, STRING=85, INTEGER_VALUE=86, DECIMAL_VALUE=87, IDENTIFIER=88,
DIGIT_IDENTIFIER=89, TABLE_IDENTIFIER=90, QUOTED_IDENTIFIER=91, BACKQUOTED_IDENTIFIER=92,
SIMPLE_COMMENT=93, BRACKETED_COMMENT=94, WS=95, UNRECOGNIZED=96;
public static String[] modeNames = {
"DEFAULT_MODE"
};
public static final String[] ruleNames = {
"T__0", "T__1", "T__2", "T__3", "ALL", "ANALYZE", "ANALYZED", "AND", "ANY",
"AS", "ASC", "BETWEEN", "BY", "CAST", "CATALOGS", "COLUMNS", "DEBUG",
"DESC", "DESCRIBE", "DISTINCT", "ESCAPE", "EXECUTABLE", "EXISTS", "EXPLAIN",
"EXTRACT", "FALSE", "FORMAT", "FROM", "FULL", "FUNCTIONS", "GRAPHVIZ",
"GROUP", "HAVING", "IN", "INNER", "IS", "JOIN", "LEFT", "LIKE", "LIMIT",
"MAPPED", "MATCH", "NATURAL", "NOT", "NULL", "ON", "OPTIMIZED", "OR",
"ORDER", "OUTER", "PARSED", "PHYSICAL", "PLAN", "RIGHT", "RLIKE", "QUERY",
"SCHEMAS", "SELECT", "SHOW", "SYS", "TABLE", "TABLES", "TEXT", "TRUE",
"TYPES", "USING", "VERIFY", "WHERE", "WITH", "EQ", "NEQ", "LT", "LTE",
"GT", "GTE", "PLUS", "MINUS", "ASTERISK", "SLASH", "PERCENT", "CONCAT",
"DOT", "STRING", "INTEGER_VALUE", "DECIMAL_VALUE", "IDENTIFIER", "DIGIT_IDENTIFIER",
"TABLE_IDENTIFIER", "QUOTED_IDENTIFIER", "BACKQUOTED_IDENTIFIER", "EXPONENT",
"DIGIT", "LETTER", "SIMPLE_COMMENT", "BRACKETED_COMMENT", "WS", "UNRECOGNIZED"
"AS", "ASC", "BETWEEN", "BY", "CAST", "CATALOG", "CATALOGS", "COLUMNS",
"DEBUG", "DESC", "DESCRIBE", "DISTINCT", "ESCAPE", "EXECUTABLE", "EXISTS",
"EXPLAIN", "EXTRACT", "FALSE", "FORMAT", "FROM", "FULL", "FUNCTIONS",
"GRAPHVIZ", "GROUP", "HAVING", "IN", "INNER", "IS", "JOIN", "LEFT", "LIKE",
"LIMIT", "MAPPED", "MATCH", "NATURAL", "NOT", "NULL", "ON", "OPTIMIZED",
"OR", "ORDER", "OUTER", "PARSED", "PHYSICAL", "PLAN", "RIGHT", "RLIKE",
"QUERY", "SCHEMAS", "SELECT", "SHOW", "SYS", "TABLE", "TABLES", "TEXT",
"TRUE", "TYPE", "TYPES", "USING", "VERIFY", "WHERE", "WITH", "EQ", "NEQ",
"LT", "LTE", "GT", "GTE", "PLUS", "MINUS", "ASTERISK", "SLASH", "PERCENT",
"CONCAT", "DOT", "STRING", "INTEGER_VALUE", "DECIMAL_VALUE", "IDENTIFIER",
"DIGIT_IDENTIFIER", "TABLE_IDENTIFIER", "QUOTED_IDENTIFIER", "BACKQUOTED_IDENTIFIER",
"EXPONENT", "DIGIT", "LETTER", "SIMPLE_COMMENT", "BRACKETED_COMMENT",
"WS", "UNRECOGNIZED"
};
private static final String[] _LITERAL_NAMES = {
null, "'('", "')'", "','", "':'", "'ALL'", "'ANALYZE'", "'ANALYZED'",
"'AND'", "'ANY'", "'AS'", "'ASC'", "'BETWEEN'", "'BY'", "'CAST'", "'CATALOGS'",
"'COLUMNS'", "'DEBUG'", "'DESC'", "'DESCRIBE'", "'DISTINCT'", "'ESCAPE'",
"'EXECUTABLE'", "'EXISTS'", "'EXPLAIN'", "'EXTRACT'", "'FALSE'", "'FORMAT'",
"'FROM'", "'FULL'", "'FUNCTIONS'", "'GRAPHVIZ'", "'GROUP'", "'HAVING'",
"'IN'", "'INNER'", "'IS'", "'JOIN'", "'LEFT'", "'LIKE'", "'LIMIT'", "'MAPPED'",
"'MATCH'", "'NATURAL'", "'NOT'", "'NULL'", "'ON'", "'OPTIMIZED'", "'OR'",
"'ORDER'", "'OUTER'", "'PARSED'", "'PHYSICAL'", "'PLAN'", "'RIGHT'", "'RLIKE'",
"'QUERY'", "'SCHEMAS'", "'SELECT'", "'SHOW'", "'SYS'", "'TABLE'", "'TABLES'",
"'TEXT'", "'TRUE'", "'TYPES'", "'USING'", "'VERIFY'", "'WHERE'", "'WITH'",
"'='", null, "'<'", "'<='", "'>'", "'>='", "'+'", "'-'", "'*'", "'/'",
"'%'", "'||'", "'.'"
"'AND'", "'ANY'", "'AS'", "'ASC'", "'BETWEEN'", "'BY'", "'CAST'", "'CATALOG'",
"'CATALOGS'", "'COLUMNS'", "'DEBUG'", "'DESC'", "'DESCRIBE'", "'DISTINCT'",
"'ESCAPE'", "'EXECUTABLE'", "'EXISTS'", "'EXPLAIN'", "'EXTRACT'", "'FALSE'",
"'FORMAT'", "'FROM'", "'FULL'", "'FUNCTIONS'", "'GRAPHVIZ'", "'GROUP'",
"'HAVING'", "'IN'", "'INNER'", "'IS'", "'JOIN'", "'LEFT'", "'LIKE'", "'LIMIT'",
"'MAPPED'", "'MATCH'", "'NATURAL'", "'NOT'", "'NULL'", "'ON'", "'OPTIMIZED'",
"'OR'", "'ORDER'", "'OUTER'", "'PARSED'", "'PHYSICAL'", "'PLAN'", "'RIGHT'",
"'RLIKE'", "'QUERY'", "'SCHEMAS'", "'SELECT'", "'SHOW'", "'SYS'", "'TABLE'",
"'TABLES'", "'TEXT'", "'TRUE'", "'TYPE'", "'TYPES'", "'USING'", "'VERIFY'",
"'WHERE'", "'WITH'", "'='", null, "'<'", "'<='", "'>'", "'>='", "'+'",
"'-'", "'*'", "'/'", "'%'", "'||'", "'.'"
};
private static final String[] _SYMBOLIC_NAMES = {
null, null, null, null, null, "ALL", "ANALYZE", "ANALYZED", "AND", "ANY",
"AS", "ASC", "BETWEEN", "BY", "CAST", "CATALOGS", "COLUMNS", "DEBUG",
"DESC", "DESCRIBE", "DISTINCT", "ESCAPE", "EXECUTABLE", "EXISTS", "EXPLAIN",
"EXTRACT", "FALSE", "FORMAT", "FROM", "FULL", "FUNCTIONS", "GRAPHVIZ",
"GROUP", "HAVING", "IN", "INNER", "IS", "JOIN", "LEFT", "LIKE", "LIMIT",
"MAPPED", "MATCH", "NATURAL", "NOT", "NULL", "ON", "OPTIMIZED", "OR",
"ORDER", "OUTER", "PARSED", "PHYSICAL", "PLAN", "RIGHT", "RLIKE", "QUERY",
"SCHEMAS", "SELECT", "SHOW", "SYS", "TABLE", "TABLES", "TEXT", "TRUE",
"TYPES", "USING", "VERIFY", "WHERE", "WITH", "EQ", "NEQ", "LT", "LTE",
"GT", "GTE", "PLUS", "MINUS", "ASTERISK", "SLASH", "PERCENT", "CONCAT",
"DOT", "STRING", "INTEGER_VALUE", "DECIMAL_VALUE", "IDENTIFIER", "DIGIT_IDENTIFIER",
"TABLE_IDENTIFIER", "QUOTED_IDENTIFIER", "BACKQUOTED_IDENTIFIER", "SIMPLE_COMMENT",
"BRACKETED_COMMENT", "WS", "UNRECOGNIZED"
"AS", "ASC", "BETWEEN", "BY", "CAST", "CATALOG", "CATALOGS", "COLUMNS",
"DEBUG", "DESC", "DESCRIBE", "DISTINCT", "ESCAPE", "EXECUTABLE", "EXISTS",
"EXPLAIN", "EXTRACT", "FALSE", "FORMAT", "FROM", "FULL", "FUNCTIONS",
"GRAPHVIZ", "GROUP", "HAVING", "IN", "INNER", "IS", "JOIN", "LEFT", "LIKE",
"LIMIT", "MAPPED", "MATCH", "NATURAL", "NOT", "NULL", "ON", "OPTIMIZED",
"OR", "ORDER", "OUTER", "PARSED", "PHYSICAL", "PLAN", "RIGHT", "RLIKE",
"QUERY", "SCHEMAS", "SELECT", "SHOW", "SYS", "TABLE", "TABLES", "TEXT",
"TRUE", "TYPE", "TYPES", "USING", "VERIFY", "WHERE", "WITH", "EQ", "NEQ",
"LT", "LTE", "GT", "GTE", "PLUS", "MINUS", "ASTERISK", "SLASH", "PERCENT",
"CONCAT", "DOT", "STRING", "INTEGER_VALUE", "DECIMAL_VALUE", "IDENTIFIER",
"DIGIT_IDENTIFIER", "TABLE_IDENTIFIER", "QUOTED_IDENTIFIER", "BACKQUOTED_IDENTIFIER",
"SIMPLE_COMMENT", "BRACKETED_COMMENT", "WS", "UNRECOGNIZED"
};
public static final Vocabulary VOCABULARY = new VocabularyImpl(_LITERAL_NAMES, _SYMBOLIC_NAMES);
@ -140,7 +141,7 @@ class SqlBaseLexer extends Lexer {
public ATN getATN() { return _ATN; }
public static final String _serializedATN =
"\3\u0430\ud6d1\u8206\uad2d\u4417\uaef1\u8d80\uaadd\2`\u0326\b\1\4\2\t"+
"\3\u0430\ud6d1\u8206\uad2d\u4417\uaef1\u8d80\uaadd\2b\u0337\b\1\4\2\t"+
"\2\4\3\t\3\4\4\t\4\4\5\t\5\4\6\t\6\4\7\t\7\4\b\t\b\4\t\t\t\4\n\t\n\4\13"+
"\t\13\4\f\t\f\4\r\t\r\4\16\t\16\4\17\t\17\4\20\t\20\4\21\t\21\4\22\t\22"+
"\4\23\t\23\4\24\t\24\4\25\t\25\4\26\t\26\4\27\t\27\4\30\t\30\4\31\t\31"+
@ -151,51 +152,52 @@ class SqlBaseLexer extends Lexer {
"\4>\t>\4?\t?\4@\t@\4A\tA\4B\tB\4C\tC\4D\tD\4E\tE\4F\tF\4G\tG\4H\tH\4I"+
"\tI\4J\tJ\4K\tK\4L\tL\4M\tM\4N\tN\4O\tO\4P\tP\4Q\tQ\4R\tR\4S\tS\4T\tT"+
"\4U\tU\4V\tV\4W\tW\4X\tX\4Y\tY\4Z\tZ\4[\t[\4\\\t\\\4]\t]\4^\t^\4_\t_\4"+
"`\t`\4a\ta\4b\tb\3\2\3\2\3\3\3\3\3\4\3\4\3\5\3\5\3\6\3\6\3\6\3\6\3\7\3"+
"\7\3\7\3\7\3\7\3\7\3\7\3\7\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\t\3\t"+
"\3\t\3\t\3\n\3\n\3\n\3\n\3\13\3\13\3\13\3\f\3\f\3\f\3\f\3\r\3\r\3\r\3"+
"\r\3\r\3\r\3\r\3\r\3\16\3\16\3\16\3\17\3\17\3\17\3\17\3\17\3\20\3\20\3"+
"\20\3\20\3\20\3\20\3\20\3\20\3\20\3\21\3\21\3\21\3\21\3\21\3\21\3\21\3"+
"\21\3\22\3\22\3\22\3\22\3\22\3\22\3\23\3\23\3\23\3\23\3\23\3\24\3\24\3"+
"\24\3\24\3\24\3\24\3\24\3\24\3\24\3\25\3\25\3\25\3\25\3\25\3\25\3\25\3"+
"\25\3\25\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\27\3\27\3\27\3\27\3\27\3"+
"\27\3\27\3\27\3\27\3\27\3\27\3\30\3\30\3\30\3\30\3\30\3\30\3\30\3\31\3"+
"\31\3\31\3\31\3\31\3\31\3\31\3\31\3\32\3\32\3\32\3\32\3\32\3\32\3\32\3"+
"\32\3\33\3\33\3\33\3\33\3\33\3\33\3\34\3\34\3\34\3\34\3\34\3\34\3\34\3"+
"\35\3\35\3\35\3\35\3\35\3\36\3\36\3\36\3\36\3\36\3\37\3\37\3\37\3\37\3"+
"\37\3\37\3\37\3\37\3\37\3\37\3 \3 \3 \3 \3 \3 \3 \3 \3 \3!\3!\3!\3!\3"+
"!\3!\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3#\3#\3#\3$\3$\3$\3$\3$\3$\3%\3%\3%\3"+
"&\3&\3&\3&\3&\3\'\3\'\3\'\3\'\3\'\3(\3(\3(\3(\3(\3)\3)\3)\3)\3)\3)\3*"+
"\3*\3*\3*\3*\3*\3*\3+\3+\3+\3+\3+\3+\3,\3,\3,\3,\3,\3,\3,\3,\3-\3-\3-"+
"\3-\3.\3.\3.\3.\3.\3/\3/\3/\3\60\3\60\3\60\3\60\3\60\3\60\3\60\3\60\3"+
"\60\3\60\3\61\3\61\3\61\3\62\3\62\3\62\3\62\3\62\3\62\3\63\3\63\3\63\3"+
"\63\3\63\3\63\3\64\3\64\3\64\3\64\3\64\3\64\3\64\3\65\3\65\3\65\3\65\3"+
"\65\3\65\3\65\3\65\3\65\3\66\3\66\3\66\3\66\3\66\3\67\3\67\3\67\3\67\3"+
"\67\3\67\38\38\38\38\38\38\39\39\39\39\39\39\3:\3:\3:\3:\3:\3:\3:\3:\3"+
";\3;\3;\3;\3;\3;\3;\3<\3<\3<\3<\3<\3=\3=\3=\3=\3>\3>\3>\3>\3>\3>\3?\3"+
"?\3?\3?\3?\3?\3?\3@\3@\3@\3@\3@\3A\3A\3A\3A\3A\3B\3B\3B\3B\3B\3B\3C\3"+
"C\3C\3C\3C\3C\3D\3D\3D\3D\3D\3D\3D\3E\3E\3E\3E\3E\3E\3F\3F\3F\3F\3F\3"+
"G\3G\3H\3H\3H\3H\3H\3H\3H\5H\u0268\nH\3I\3I\3J\3J\3J\3K\3K\3L\3L\3L\3"+
"M\3M\3N\3N\3O\3O\3P\3P\3Q\3Q\3R\3R\3R\3S\3S\3T\3T\3T\3T\7T\u0287\nT\f"+
"T\16T\u028a\13T\3T\3T\3U\6U\u028f\nU\rU\16U\u0290\3V\6V\u0294\nV\rV\16"+
"V\u0295\3V\3V\7V\u029a\nV\fV\16V\u029d\13V\3V\3V\6V\u02a1\nV\rV\16V\u02a2"+
"\3V\6V\u02a6\nV\rV\16V\u02a7\3V\3V\7V\u02ac\nV\fV\16V\u02af\13V\5V\u02b1"+
"\nV\3V\3V\3V\3V\6V\u02b7\nV\rV\16V\u02b8\3V\3V\5V\u02bd\nV\3W\3W\5W\u02c1"+
"\nW\3W\3W\3W\7W\u02c6\nW\fW\16W\u02c9\13W\3X\3X\3X\3X\6X\u02cf\nX\rX\16"+
"X\u02d0\3Y\3Y\3Y\3Y\6Y\u02d7\nY\rY\16Y\u02d8\3Z\3Z\3Z\3Z\7Z\u02df\nZ\f"+
"Z\16Z\u02e2\13Z\3Z\3Z\3[\3[\3[\3[\7[\u02ea\n[\f[\16[\u02ed\13[\3[\3[\3"+
"\\\3\\\5\\\u02f3\n\\\3\\\6\\\u02f6\n\\\r\\\16\\\u02f7\3]\3]\3^\3^\3_\3"+
"_\3_\3_\7_\u0302\n_\f_\16_\u0305\13_\3_\5_\u0308\n_\3_\5_\u030b\n_\3_"+
"\3_\3`\3`\3`\3`\3`\7`\u0314\n`\f`\16`\u0317\13`\3`\3`\3`\3`\3`\3a\6a\u031f"+
"\na\ra\16a\u0320\3a\3a\3b\3b\3\u0315\2c\3\3\5\4\7\5\t\6\13\7\r\b\17\t"+
"\21\n\23\13\25\f\27\r\31\16\33\17\35\20\37\21!\22#\23%\24\'\25)\26+\27"+
"-\30/\31\61\32\63\33\65\34\67\359\36;\37= ?!A\"C#E$G%I&K\'M(O)Q*S+U,W"+
"-Y.[/]\60_\61a\62c\63e\64g\65i\66k\67m8o9q:s;u<w=y>{?}@\177A\u0081B\u0083"+
"C\u0085D\u0087E\u0089F\u008bG\u008dH\u008fI\u0091J\u0093K\u0095L\u0097"+
"M\u0099N\u009bO\u009dP\u009fQ\u00a1R\u00a3S\u00a5T\u00a7U\u00a9V\u00ab"+
"W\u00adX\u00afY\u00b1Z\u00b3[\u00b5\\\u00b7\2\u00b9\2\u00bb\2\u00bd]\u00bf"+
"^\u00c1_\u00c3`\3\2\f\3\2))\4\2BBaa\5\2<<BBaa\3\2$$\3\2bb\4\2--//\3\2"+
"\62;\3\2C\\\4\2\f\f\17\17\5\2\13\f\17\17\"\"\u0348\2\3\3\2\2\2\2\5\3\2"+
"`\t`\4a\ta\4b\tb\4c\tc\4d\td\3\2\3\2\3\3\3\3\3\4\3\4\3\5\3\5\3\6\3\6\3"+
"\6\3\6\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3\7\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\b"+
"\3\b\3\t\3\t\3\t\3\t\3\n\3\n\3\n\3\n\3\13\3\13\3\13\3\f\3\f\3\f\3\f\3"+
"\r\3\r\3\r\3\r\3\r\3\r\3\r\3\r\3\16\3\16\3\16\3\17\3\17\3\17\3\17\3\17"+
"\3\20\3\20\3\20\3\20\3\20\3\20\3\20\3\20\3\21\3\21\3\21\3\21\3\21\3\21"+
"\3\21\3\21\3\21\3\22\3\22\3\22\3\22\3\22\3\22\3\22\3\22\3\23\3\23\3\23"+
"\3\23\3\23\3\23\3\24\3\24\3\24\3\24\3\24\3\25\3\25\3\25\3\25\3\25\3\25"+
"\3\25\3\25\3\25\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\27\3\27"+
"\3\27\3\27\3\27\3\27\3\27\3\30\3\30\3\30\3\30\3\30\3\30\3\30\3\30\3\30"+
"\3\30\3\30\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\32\3\32\3\32\3\32\3\32"+
"\3\32\3\32\3\32\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\33\3\34\3\34\3\34"+
"\3\34\3\34\3\34\3\35\3\35\3\35\3\35\3\35\3\35\3\35\3\36\3\36\3\36\3\36"+
"\3\36\3\37\3\37\3\37\3\37\3\37\3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3!\3!\3!"+
"\3!\3!\3!\3!\3!\3!\3\"\3\"\3\"\3\"\3\"\3\"\3#\3#\3#\3#\3#\3#\3#\3$\3$"+
"\3$\3%\3%\3%\3%\3%\3%\3&\3&\3&\3\'\3\'\3\'\3\'\3\'\3(\3(\3(\3(\3(\3)\3"+
")\3)\3)\3)\3*\3*\3*\3*\3*\3*\3+\3+\3+\3+\3+\3+\3+\3,\3,\3,\3,\3,\3,\3"+
"-\3-\3-\3-\3-\3-\3-\3-\3.\3.\3.\3.\3/\3/\3/\3/\3/\3\60\3\60\3\60\3\61"+
"\3\61\3\61\3\61\3\61\3\61\3\61\3\61\3\61\3\61\3\62\3\62\3\62\3\63\3\63"+
"\3\63\3\63\3\63\3\63\3\64\3\64\3\64\3\64\3\64\3\64\3\65\3\65\3\65\3\65"+
"\3\65\3\65\3\65\3\66\3\66\3\66\3\66\3\66\3\66\3\66\3\66\3\66\3\67\3\67"+
"\3\67\3\67\3\67\38\38\38\38\38\38\39\39\39\39\39\39\3:\3:\3:\3:\3:\3:"+
"\3;\3;\3;\3;\3;\3;\3;\3;\3<\3<\3<\3<\3<\3<\3<\3=\3=\3=\3=\3=\3>\3>\3>"+
"\3>\3?\3?\3?\3?\3?\3?\3@\3@\3@\3@\3@\3@\3@\3A\3A\3A\3A\3A\3B\3B\3B\3B"+
"\3B\3C\3C\3C\3C\3C\3D\3D\3D\3D\3D\3D\3E\3E\3E\3E\3E\3E\3F\3F\3F\3F\3F"+
"\3F\3F\3G\3G\3G\3G\3G\3G\3H\3H\3H\3H\3H\3I\3I\3J\3J\3J\3J\3J\3J\3J\5J"+
"\u0279\nJ\3K\3K\3L\3L\3L\3M\3M\3N\3N\3N\3O\3O\3P\3P\3Q\3Q\3R\3R\3S\3S"+
"\3T\3T\3T\3U\3U\3V\3V\3V\3V\7V\u0298\nV\fV\16V\u029b\13V\3V\3V\3W\6W\u02a0"+
"\nW\rW\16W\u02a1\3X\6X\u02a5\nX\rX\16X\u02a6\3X\3X\7X\u02ab\nX\fX\16X"+
"\u02ae\13X\3X\3X\6X\u02b2\nX\rX\16X\u02b3\3X\6X\u02b7\nX\rX\16X\u02b8"+
"\3X\3X\7X\u02bd\nX\fX\16X\u02c0\13X\5X\u02c2\nX\3X\3X\3X\3X\6X\u02c8\n"+
"X\rX\16X\u02c9\3X\3X\5X\u02ce\nX\3Y\3Y\5Y\u02d2\nY\3Y\3Y\3Y\7Y\u02d7\n"+
"Y\fY\16Y\u02da\13Y\3Z\3Z\3Z\3Z\6Z\u02e0\nZ\rZ\16Z\u02e1\3[\3[\3[\3[\6"+
"[\u02e8\n[\r[\16[\u02e9\3\\\3\\\3\\\3\\\7\\\u02f0\n\\\f\\\16\\\u02f3\13"+
"\\\3\\\3\\\3]\3]\3]\3]\7]\u02fb\n]\f]\16]\u02fe\13]\3]\3]\3^\3^\5^\u0304"+
"\n^\3^\6^\u0307\n^\r^\16^\u0308\3_\3_\3`\3`\3a\3a\3a\3a\7a\u0313\na\f"+
"a\16a\u0316\13a\3a\5a\u0319\na\3a\5a\u031c\na\3a\3a\3b\3b\3b\3b\3b\7b"+
"\u0325\nb\fb\16b\u0328\13b\3b\3b\3b\3b\3b\3c\6c\u0330\nc\rc\16c\u0331"+
"\3c\3c\3d\3d\3\u0326\2e\3\3\5\4\7\5\t\6\13\7\r\b\17\t\21\n\23\13\25\f"+
"\27\r\31\16\33\17\35\20\37\21!\22#\23%\24\'\25)\26+\27-\30/\31\61\32\63"+
"\33\65\34\67\359\36;\37= ?!A\"C#E$G%I&K\'M(O)Q*S+U,W-Y.[/]\60_\61a\62"+
"c\63e\64g\65i\66k\67m8o9q:s;u<w=y>{?}@\177A\u0081B\u0083C\u0085D\u0087"+
"E\u0089F\u008bG\u008dH\u008fI\u0091J\u0093K\u0095L\u0097M\u0099N\u009b"+
"O\u009dP\u009fQ\u00a1R\u00a3S\u00a5T\u00a7U\u00a9V\u00abW\u00adX\u00af"+
"Y\u00b1Z\u00b3[\u00b5\\\u00b7]\u00b9^\u00bb\2\u00bd\2\u00bf\2\u00c1_\u00c3"+
"`\u00c5a\u00c7b\3\2\f\3\2))\4\2BBaa\5\2<<BBaa\3\2$$\3\2bb\4\2--//\3\2"+
"\62;\3\2C\\\4\2\f\f\17\17\5\2\13\f\17\17\"\"\u0359\2\3\3\2\2\2\2\5\3\2"+
"\2\2\2\7\3\2\2\2\2\t\3\2\2\2\2\13\3\2\2\2\2\r\3\2\2\2\2\17\3\2\2\2\2\21"+
"\3\2\2\2\2\23\3\2\2\2\2\25\3\2\2\2\2\27\3\2\2\2\2\31\3\2\2\2\2\33\3\2"+
"\2\2\2\35\3\2\2\2\2\37\3\2\2\2\2!\3\2\2\2\2#\3\2\2\2\2%\3\2\2\2\2\'\3"+
@ -212,208 +214,212 @@ class SqlBaseLexer extends Lexer {
"\3\2\2\2\2\u009b\3\2\2\2\2\u009d\3\2\2\2\2\u009f\3\2\2\2\2\u00a1\3\2\2"+
"\2\2\u00a3\3\2\2\2\2\u00a5\3\2\2\2\2\u00a7\3\2\2\2\2\u00a9\3\2\2\2\2\u00ab"+
"\3\2\2\2\2\u00ad\3\2\2\2\2\u00af\3\2\2\2\2\u00b1\3\2\2\2\2\u00b3\3\2\2"+
"\2\2\u00b5\3\2\2\2\2\u00bd\3\2\2\2\2\u00bf\3\2\2\2\2\u00c1\3\2\2\2\2\u00c3"+
"\3\2\2\2\3\u00c5\3\2\2\2\5\u00c7\3\2\2\2\7\u00c9\3\2\2\2\t\u00cb\3\2\2"+
"\2\13\u00cd\3\2\2\2\r\u00d1\3\2\2\2\17\u00d9\3\2\2\2\21\u00e2\3\2\2\2"+
"\23\u00e6\3\2\2\2\25\u00ea\3\2\2\2\27\u00ed\3\2\2\2\31\u00f1\3\2\2\2\33"+
"\u00f9\3\2\2\2\35\u00fc\3\2\2\2\37\u0101\3\2\2\2!\u010a\3\2\2\2#\u0112"+
"\3\2\2\2%\u0118\3\2\2\2\'\u011d\3\2\2\2)\u0126\3\2\2\2+\u012f\3\2\2\2"+
"-\u0136\3\2\2\2/\u0141\3\2\2\2\61\u0148\3\2\2\2\63\u0150\3\2\2\2\65\u0158"+
"\3\2\2\2\67\u015e\3\2\2\29\u0165\3\2\2\2;\u016a\3\2\2\2=\u016f\3\2\2\2"+
"?\u0179\3\2\2\2A\u0182\3\2\2\2C\u0188\3\2\2\2E\u018f\3\2\2\2G\u0192\3"+
"\2\2\2I\u0198\3\2\2\2K\u019b\3\2\2\2M\u01a0\3\2\2\2O\u01a5\3\2\2\2Q\u01aa"+
"\3\2\2\2S\u01b0\3\2\2\2U\u01b7\3\2\2\2W\u01bd\3\2\2\2Y\u01c5\3\2\2\2["+
"\u01c9\3\2\2\2]\u01ce\3\2\2\2_\u01d1\3\2\2\2a\u01db\3\2\2\2c\u01de\3\2"+
"\2\2e\u01e4\3\2\2\2g\u01ea\3\2\2\2i\u01f1\3\2\2\2k\u01fa\3\2\2\2m\u01ff"+
"\3\2\2\2o\u0205\3\2\2\2q\u020b\3\2\2\2s\u0211\3\2\2\2u\u0219\3\2\2\2w"+
"\u0220\3\2\2\2y\u0225\3\2\2\2{\u0229\3\2\2\2}\u022f\3\2\2\2\177\u0236"+
"\3\2\2\2\u0081\u023b\3\2\2\2\u0083\u0240\3\2\2\2\u0085\u0246\3\2\2\2\u0087"+
"\u024c\3\2\2\2\u0089\u0253\3\2\2\2\u008b\u0259\3\2\2\2\u008d\u025e\3\2"+
"\2\2\u008f\u0267\3\2\2\2\u0091\u0269\3\2\2\2\u0093\u026b\3\2\2\2\u0095"+
"\u026e\3\2\2\2\u0097\u0270\3\2\2\2\u0099\u0273\3\2\2\2\u009b\u0275\3\2"+
"\2\2\u009d\u0277\3\2\2\2\u009f\u0279\3\2\2\2\u00a1\u027b\3\2\2\2\u00a3"+
"\u027d\3\2\2\2\u00a5\u0280\3\2\2\2\u00a7\u0282\3\2\2\2\u00a9\u028e\3\2"+
"\2\2\u00ab\u02bc\3\2\2\2\u00ad\u02c0\3\2\2\2\u00af\u02ca\3\2\2\2\u00b1"+
"\u02d6\3\2\2\2\u00b3\u02da\3\2\2\2\u00b5\u02e5\3\2\2\2\u00b7\u02f0\3\2"+
"\2\2\u00b9\u02f9\3\2\2\2\u00bb\u02fb\3\2\2\2\u00bd\u02fd\3\2\2\2\u00bf"+
"\u030e\3\2\2\2\u00c1\u031e\3\2\2\2\u00c3\u0324\3\2\2\2\u00c5\u00c6\7*"+
"\2\2\u00c6\4\3\2\2\2\u00c7\u00c8\7+\2\2\u00c8\6\3\2\2\2\u00c9\u00ca\7"+
".\2\2\u00ca\b\3\2\2\2\u00cb\u00cc\7<\2\2\u00cc\n\3\2\2\2\u00cd\u00ce\7"+
"C\2\2\u00ce\u00cf\7N\2\2\u00cf\u00d0\7N\2\2\u00d0\f\3\2\2\2\u00d1\u00d2"+
"\7C\2\2\u00d2\u00d3\7P\2\2\u00d3\u00d4\7C\2\2\u00d4\u00d5\7N\2\2\u00d5"+
"\u00d6\7[\2\2\u00d6\u00d7\7\\\2\2\u00d7\u00d8\7G\2\2\u00d8\16\3\2\2\2"+
"\u00d9\u00da\7C\2\2\u00da\u00db\7P\2\2\u00db\u00dc\7C\2\2\u00dc\u00dd"+
"\7N\2\2\u00dd\u00de\7[\2\2\u00de\u00df\7\\\2\2\u00df\u00e0\7G\2\2\u00e0"+
"\u00e1\7F\2\2\u00e1\20\3\2\2\2\u00e2\u00e3\7C\2\2\u00e3\u00e4\7P\2\2\u00e4"+
"\u00e5\7F\2\2\u00e5\22\3\2\2\2\u00e6\u00e7\7C\2\2\u00e7\u00e8\7P\2\2\u00e8"+
"\u00e9\7[\2\2\u00e9\24\3\2\2\2\u00ea\u00eb\7C\2\2\u00eb\u00ec\7U\2\2\u00ec"+
"\26\3\2\2\2\u00ed\u00ee\7C\2\2\u00ee\u00ef\7U\2\2\u00ef\u00f0\7E\2\2\u00f0"+
"\30\3\2\2\2\u00f1\u00f2\7D\2\2\u00f2\u00f3\7G\2\2\u00f3\u00f4\7V\2\2\u00f4"+
"\u00f5\7Y\2\2\u00f5\u00f6\7G\2\2\u00f6\u00f7\7G\2\2\u00f7\u00f8\7P\2\2"+
"\u00f8\32\3\2\2\2\u00f9\u00fa\7D\2\2\u00fa\u00fb\7[\2\2\u00fb\34\3\2\2"+
"\2\u00fc\u00fd\7E\2\2\u00fd\u00fe\7C\2\2\u00fe\u00ff\7U\2\2\u00ff\u0100"+
"\7V\2\2\u0100\36\3\2\2\2\u0101\u0102\7E\2\2\u0102\u0103\7C\2\2\u0103\u0104"+
"\7V\2\2\u0104\u0105\7C\2\2\u0105\u0106\7N\2\2\u0106\u0107\7Q\2\2\u0107"+
"\u0108\7I\2\2\u0108\u0109\7U\2\2\u0109 \3\2\2\2\u010a\u010b\7E\2\2\u010b"+
"\u010c\7Q\2\2\u010c\u010d\7N\2\2\u010d\u010e\7W\2\2\u010e\u010f\7O\2\2"+
"\u010f\u0110\7P\2\2\u0110\u0111\7U\2\2\u0111\"\3\2\2\2\u0112\u0113\7F"+
"\2\2\u0113\u0114\7G\2\2\u0114\u0115\7D\2\2\u0115\u0116\7W\2\2\u0116\u0117"+
"\7I\2\2\u0117$\3\2\2\2\u0118\u0119\7F\2\2\u0119\u011a\7G\2\2\u011a\u011b"+
"\7U\2\2\u011b\u011c\7E\2\2\u011c&\3\2\2\2\u011d\u011e\7F\2\2\u011e\u011f"+
"\7G\2\2\u011f\u0120\7U\2\2\u0120\u0121\7E\2\2\u0121\u0122\7T\2\2\u0122"+
"\u0123\7K\2\2\u0123\u0124\7D\2\2\u0124\u0125\7G\2\2\u0125(\3\2\2\2\u0126"+
"\u0127\7F\2\2\u0127\u0128\7K\2\2\u0128\u0129\7U\2\2\u0129\u012a\7V\2\2"+
"\u012a\u012b\7K\2\2\u012b\u012c\7P\2\2\u012c\u012d\7E\2\2\u012d\u012e"+
"\7V\2\2\u012e*\3\2\2\2\u012f\u0130\7G\2\2\u0130\u0131\7U\2\2\u0131\u0132"+
"\7E\2\2\u0132\u0133\7C\2\2\u0133\u0134\7R\2\2\u0134\u0135\7G\2\2\u0135"+
",\3\2\2\2\u0136\u0137\7G\2\2\u0137\u0138\7Z\2\2\u0138\u0139\7G\2\2\u0139"+
"\u013a\7E\2\2\u013a\u013b\7W\2\2\u013b\u013c\7V\2\2\u013c\u013d\7C\2\2"+
"\u013d\u013e\7D\2\2\u013e\u013f\7N\2\2\u013f\u0140\7G\2\2\u0140.\3\2\2"+
"\2\u0141\u0142\7G\2\2\u0142\u0143\7Z\2\2\u0143\u0144\7K\2\2\u0144\u0145"+
"\7U\2\2\u0145\u0146\7V\2\2\u0146\u0147\7U\2\2\u0147\60\3\2\2\2\u0148\u0149"+
"\7G\2\2\u0149\u014a\7Z\2\2\u014a\u014b\7R\2\2\u014b\u014c\7N\2\2\u014c"+
"\u014d\7C\2\2\u014d\u014e\7K\2\2\u014e\u014f\7P\2\2\u014f\62\3\2\2\2\u0150"+
"\u0151\7G\2\2\u0151\u0152\7Z\2\2\u0152\u0153\7V\2\2\u0153\u0154\7T\2\2"+
"\u0154\u0155\7C\2\2\u0155\u0156\7E\2\2\u0156\u0157\7V\2\2\u0157\64\3\2"+
"\2\2\u0158\u0159\7H\2\2\u0159\u015a\7C\2\2\u015a\u015b\7N\2\2\u015b\u015c"+
"\7U\2\2\u015c\u015d\7G\2\2\u015d\66\3\2\2\2\u015e\u015f\7H\2\2\u015f\u0160"+
"\7Q\2\2\u0160\u0161\7T\2\2\u0161\u0162\7O\2\2\u0162\u0163\7C\2\2\u0163"+
"\u0164\7V\2\2\u01648\3\2\2\2\u0165\u0166\7H\2\2\u0166\u0167\7T\2\2\u0167"+
"\u0168\7Q\2\2\u0168\u0169\7O\2\2\u0169:\3\2\2\2\u016a\u016b\7H\2\2\u016b"+
"\u016c\7W\2\2\u016c\u016d\7N\2\2\u016d\u016e\7N\2\2\u016e<\3\2\2\2\u016f"+
"\u0170\7H\2\2\u0170\u0171\7W\2\2\u0171\u0172\7P\2\2\u0172\u0173\7E\2\2"+
"\u0173\u0174\7V\2\2\u0174\u0175\7K\2\2\u0175\u0176\7Q\2\2\u0176\u0177"+
"\7P\2\2\u0177\u0178\7U\2\2\u0178>\3\2\2\2\u0179\u017a\7I\2\2\u017a\u017b"+
"\7T\2\2\u017b\u017c\7C\2\2\u017c\u017d\7R\2\2\u017d\u017e\7J\2\2\u017e"+
"\u017f\7X\2\2\u017f\u0180\7K\2\2\u0180\u0181\7\\\2\2\u0181@\3\2\2\2\u0182"+
"\u0183\7I\2\2\u0183\u0184\7T\2\2\u0184\u0185\7Q\2\2\u0185\u0186\7W\2\2"+
"\u0186\u0187\7R\2\2\u0187B\3\2\2\2\u0188\u0189\7J\2\2\u0189\u018a\7C\2"+
"\2\u018a\u018b\7X\2\2\u018b\u018c\7K\2\2\u018c\u018d\7P\2\2\u018d\u018e"+
"\7I\2\2\u018eD\3\2\2\2\u018f\u0190\7K\2\2\u0190\u0191\7P\2\2\u0191F\3"+
"\2\2\2\u0192\u0193\7K\2\2\u0193\u0194\7P\2\2\u0194\u0195\7P\2\2\u0195"+
"\u0196\7G\2\2\u0196\u0197\7T\2\2\u0197H\3\2\2\2\u0198\u0199\7K\2\2\u0199"+
"\u019a\7U\2\2\u019aJ\3\2\2\2\u019b\u019c\7L\2\2\u019c\u019d\7Q\2\2\u019d"+
"\u019e\7K\2\2\u019e\u019f\7P\2\2\u019fL\3\2\2\2\u01a0\u01a1\7N\2\2\u01a1"+
"\u01a2\7G\2\2\u01a2\u01a3\7H\2\2\u01a3\u01a4\7V\2\2\u01a4N\3\2\2\2\u01a5"+
"\u01a6\7N\2\2\u01a6\u01a7\7K\2\2\u01a7\u01a8\7M\2\2\u01a8\u01a9\7G\2\2"+
"\u01a9P\3\2\2\2\u01aa\u01ab\7N\2\2\u01ab\u01ac\7K\2\2\u01ac\u01ad\7O\2"+
"\2\u01ad\u01ae\7K\2\2\u01ae\u01af\7V\2\2\u01afR\3\2\2\2\u01b0\u01b1\7"+
"O\2\2\u01b1\u01b2\7C\2\2\u01b2\u01b3\7R\2\2\u01b3\u01b4\7R\2\2\u01b4\u01b5"+
"\7G\2\2\u01b5\u01b6\7F\2\2\u01b6T\3\2\2\2\u01b7\u01b8\7O\2\2\u01b8\u01b9"+
"\7C\2\2\u01b9\u01ba\7V\2\2\u01ba\u01bb\7E\2\2\u01bb\u01bc\7J\2\2\u01bc"+
"V\3\2\2\2\u01bd\u01be\7P\2\2\u01be\u01bf\7C\2\2\u01bf\u01c0\7V\2\2\u01c0"+
"\u01c1\7W\2\2\u01c1\u01c2\7T\2\2\u01c2\u01c3\7C\2\2\u01c3\u01c4\7N\2\2"+
"\u01c4X\3\2\2\2\u01c5\u01c6\7P\2\2\u01c6\u01c7\7Q\2\2\u01c7\u01c8\7V\2"+
"\2\u01c8Z\3\2\2\2\u01c9\u01ca\7P\2\2\u01ca\u01cb\7W\2\2\u01cb\u01cc\7"+
"N\2\2\u01cc\u01cd\7N\2\2\u01cd\\\3\2\2\2\u01ce\u01cf\7Q\2\2\u01cf\u01d0"+
"\7P\2\2\u01d0^\3\2\2\2\u01d1\u01d2\7Q\2\2\u01d2\u01d3\7R\2\2\u01d3\u01d4"+
"\7V\2\2\u01d4\u01d5\7K\2\2\u01d5\u01d6\7O\2\2\u01d6\u01d7\7K\2\2\u01d7"+
"\u01d8\7\\\2\2\u01d8\u01d9\7G\2\2\u01d9\u01da\7F\2\2\u01da`\3\2\2\2\u01db"+
"\u01dc\7Q\2\2\u01dc\u01dd\7T\2\2\u01ddb\3\2\2\2\u01de\u01df\7Q\2\2\u01df"+
"\u01e0\7T\2\2\u01e0\u01e1\7F\2\2\u01e1\u01e2\7G\2\2\u01e2\u01e3\7T\2\2"+
"\u01e3d\3\2\2\2\u01e4\u01e5\7Q\2\2\u01e5\u01e6\7W\2\2\u01e6\u01e7\7V\2"+
"\2\u01e7\u01e8\7G\2\2\u01e8\u01e9\7T\2\2\u01e9f\3\2\2\2\u01ea\u01eb\7"+
"R\2\2\u01eb\u01ec\7C\2\2\u01ec\u01ed\7T\2\2\u01ed\u01ee\7U\2\2\u01ee\u01ef"+
"\7G\2\2\u01ef\u01f0\7F\2\2\u01f0h\3\2\2\2\u01f1\u01f2\7R\2\2\u01f2\u01f3"+
"\7J\2\2\u01f3\u01f4\7[\2\2\u01f4\u01f5\7U\2\2\u01f5\u01f6\7K\2\2\u01f6"+
"\u01f7\7E\2\2\u01f7\u01f8\7C\2\2\u01f8\u01f9\7N\2\2\u01f9j\3\2\2\2\u01fa"+
"\u01fb\7R\2\2\u01fb\u01fc\7N\2\2\u01fc\u01fd\7C\2\2\u01fd\u01fe\7P\2\2"+
"\u01fel\3\2\2\2\u01ff\u0200\7T\2\2\u0200\u0201\7K\2\2\u0201\u0202\7I\2"+
"\2\u0202\u0203\7J\2\2\u0203\u0204\7V\2\2\u0204n\3\2\2\2\u0205\u0206\7"+
"T\2\2\u0206\u0207\7N\2\2\u0207\u0208\7K\2\2\u0208\u0209\7M\2\2\u0209\u020a"+
"\7G\2\2\u020ap\3\2\2\2\u020b\u020c\7S\2\2\u020c\u020d\7W\2\2\u020d\u020e"+
"\7G\2\2\u020e\u020f\7T\2\2\u020f\u0210\7[\2\2\u0210r\3\2\2\2\u0211\u0212"+
"\7U\2\2\u0212\u0213\7E\2\2\u0213\u0214\7J\2\2\u0214\u0215\7G\2\2\u0215"+
"\u0216\7O\2\2\u0216\u0217\7C\2\2\u0217\u0218\7U\2\2\u0218t\3\2\2\2\u0219"+
"\u021a\7U\2\2\u021a\u021b\7G\2\2\u021b\u021c\7N\2\2\u021c\u021d\7G\2\2"+
"\u021d\u021e\7E\2\2\u021e\u021f\7V\2\2\u021fv\3\2\2\2\u0220\u0221\7U\2"+
"\2\u0221\u0222\7J\2\2\u0222\u0223\7Q\2\2\u0223\u0224\7Y\2\2\u0224x\3\2"+
"\2\2\u0225\u0226\7U\2\2\u0226\u0227\7[\2\2\u0227\u0228\7U\2\2\u0228z\3"+
"\2\2\2\u0229\u022a\7V\2\2\u022a\u022b\7C\2\2\u022b\u022c\7D\2\2\u022c"+
"\u022d\7N\2\2\u022d\u022e\7G\2\2\u022e|\3\2\2\2\u022f\u0230\7V\2\2\u0230"+
"\u0231\7C\2\2\u0231\u0232\7D\2\2\u0232\u0233\7N\2\2\u0233\u0234\7G\2\2"+
"\u0234\u0235\7U\2\2\u0235~\3\2\2\2\u0236\u0237\7V\2\2\u0237\u0238\7G\2"+
"\2\u0238\u0239\7Z\2\2\u0239\u023a\7V\2\2\u023a\u0080\3\2\2\2\u023b\u023c"+
"\7V\2\2\u023c\u023d\7T\2\2\u023d\u023e\7W\2\2\u023e\u023f\7G\2\2\u023f"+
"\u0082\3\2\2\2\u0240\u0241\7V\2\2\u0241\u0242\7[\2\2\u0242\u0243\7R\2"+
"\2\u0243\u0244\7G\2\2\u0244\u0245\7U\2\2\u0245\u0084\3\2\2\2\u0246\u0247"+
"\7W\2\2\u0247\u0248\7U\2\2\u0248\u0249\7K\2\2\u0249\u024a\7P\2\2\u024a"+
"\u024b\7I\2\2\u024b\u0086\3\2\2\2\u024c\u024d\7X\2\2\u024d\u024e\7G\2"+
"\2\u024e\u024f\7T\2\2\u024f\u0250\7K\2\2\u0250\u0251\7H\2\2\u0251\u0252"+
"\7[\2\2\u0252\u0088\3\2\2\2\u0253\u0254\7Y\2\2\u0254\u0255\7J\2\2\u0255"+
"\u0256\7G\2\2\u0256\u0257\7T\2\2\u0257\u0258\7G\2\2\u0258\u008a\3\2\2"+
"\2\u0259\u025a\7Y\2\2\u025a\u025b\7K\2\2\u025b\u025c\7V\2\2\u025c\u025d"+
"\7J\2\2\u025d\u008c\3\2\2\2\u025e\u025f\7?\2\2\u025f\u008e\3\2\2\2\u0260"+
"\u0261\7>\2\2\u0261\u0268\7@\2\2\u0262\u0263\7#\2\2\u0263\u0268\7?\2\2"+
"\u0264\u0265\7>\2\2\u0265\u0266\7?\2\2\u0266\u0268\7@\2\2\u0267\u0260"+
"\3\2\2\2\u0267\u0262\3\2\2\2\u0267\u0264\3\2\2\2\u0268\u0090\3\2\2\2\u0269"+
"\u026a\7>\2\2\u026a\u0092\3\2\2\2\u026b\u026c\7>\2\2\u026c\u026d\7?\2"+
"\2\u026d\u0094\3\2\2\2\u026e\u026f\7@\2\2\u026f\u0096\3\2\2\2\u0270\u0271"+
"\7@\2\2\u0271\u0272\7?\2\2\u0272\u0098\3\2\2\2\u0273\u0274\7-\2\2\u0274"+
"\u009a\3\2\2\2\u0275\u0276\7/\2\2\u0276\u009c\3\2\2\2\u0277\u0278\7,\2"+
"\2\u0278\u009e\3\2\2\2\u0279\u027a\7\61\2\2\u027a\u00a0\3\2\2\2\u027b"+
"\u027c\7\'\2\2\u027c\u00a2\3\2\2\2\u027d\u027e\7~\2\2\u027e\u027f\7~\2"+
"\2\u027f\u00a4\3\2\2\2\u0280\u0281\7\60\2\2\u0281\u00a6\3\2\2\2\u0282"+
"\u0288\7)\2\2\u0283\u0287\n\2\2\2\u0284\u0285\7)\2\2\u0285\u0287\7)\2"+
"\2\u0286\u0283\3\2\2\2\u0286\u0284\3\2\2\2\u0287\u028a\3\2\2\2\u0288\u0286"+
"\3\2\2\2\u0288\u0289\3\2\2\2\u0289\u028b\3\2\2\2\u028a\u0288\3\2\2\2\u028b"+
"\u028c\7)\2\2\u028c\u00a8\3\2\2\2\u028d\u028f\5\u00b9]\2\u028e\u028d\3"+
"\2\2\2\u028f\u0290\3\2\2\2\u0290\u028e\3\2\2\2\u0290\u0291\3\2\2\2\u0291"+
"\u00aa\3\2\2\2\u0292\u0294\5\u00b9]\2\u0293\u0292\3\2\2\2\u0294\u0295"+
"\3\2\2\2\u0295\u0293\3\2\2\2\u0295\u0296\3\2\2\2\u0296\u0297\3\2\2\2\u0297"+
"\u029b\5\u00a5S\2\u0298\u029a\5\u00b9]\2\u0299\u0298\3\2\2\2\u029a\u029d"+
"\3\2\2\2\u029b\u0299\3\2\2\2\u029b\u029c\3\2\2\2\u029c\u02bd\3\2\2\2\u029d"+
"\u029b\3\2\2\2\u029e\u02a0\5\u00a5S\2\u029f\u02a1\5\u00b9]\2\u02a0\u029f"+
"\3\2\2\2\u02a1\u02a2\3\2\2\2\u02a2\u02a0\3\2\2\2\u02a2\u02a3\3\2\2\2\u02a3"+
"\u02bd\3\2\2\2\u02a4\u02a6\5\u00b9]\2\u02a5\u02a4\3\2\2\2\u02a6\u02a7"+
"\3\2\2\2\u02a7\u02a5\3\2\2\2\u02a7\u02a8\3\2\2\2\u02a8\u02b0\3\2\2\2\u02a9"+
"\u02ad\5\u00a5S\2\u02aa\u02ac\5\u00b9]\2\u02ab\u02aa\3\2\2\2\u02ac\u02af"+
"\3\2\2\2\u02ad\u02ab\3\2\2\2\u02ad\u02ae\3\2\2\2\u02ae\u02b1\3\2\2\2\u02af"+
"\u02ad\3\2\2\2\u02b0\u02a9\3\2\2\2\u02b0\u02b1\3\2\2\2\u02b1\u02b2\3\2"+
"\2\2\u02b2\u02b3\5\u00b7\\\2\u02b3\u02bd\3\2\2\2\u02b4\u02b6\5\u00a5S"+
"\2\u02b5\u02b7\5\u00b9]\2\u02b6\u02b5\3\2\2\2\u02b7\u02b8\3\2\2\2\u02b8"+
"\u02b6\3\2\2\2\u02b8\u02b9\3\2\2\2\u02b9\u02ba\3\2\2\2\u02ba\u02bb\5\u00b7"+
"\\\2\u02bb\u02bd\3\2\2\2\u02bc\u0293\3\2\2\2\u02bc\u029e\3\2\2\2\u02bc"+
"\u02a5\3\2\2\2\u02bc\u02b4\3\2\2\2\u02bd\u00ac\3\2\2\2\u02be\u02c1\5\u00bb"+
"^\2\u02bf\u02c1\7a\2\2\u02c0\u02be\3\2\2\2\u02c0\u02bf\3\2\2\2\u02c1\u02c7"+
"\3\2\2\2\u02c2\u02c6\5\u00bb^\2\u02c3\u02c6\5\u00b9]\2\u02c4\u02c6\t\3"+
"\2\2\u02c5\u02c2\3\2\2\2\u02c5\u02c3\3\2\2\2\u02c5\u02c4\3\2\2\2\u02c6"+
"\u02c9\3\2\2\2\u02c7\u02c5\3\2\2\2\u02c7\u02c8\3\2\2\2\u02c8\u00ae\3\2"+
"\2\2\u02c9\u02c7\3\2\2\2\u02ca\u02ce\5\u00b9]\2\u02cb\u02cf\5\u00bb^\2"+
"\u02cc\u02cf\5\u00b9]\2\u02cd\u02cf\t\4\2\2\u02ce\u02cb\3\2\2\2\u02ce"+
"\u02cc\3\2\2\2\u02ce\u02cd\3\2\2\2\u02cf\u02d0\3\2\2\2\u02d0\u02ce\3\2"+
"\2\2\u02d0\u02d1\3\2\2\2\u02d1\u00b0\3\2\2\2\u02d2\u02d7\5\u00bb^\2\u02d3"+
"\u02d7\5\u00b9]\2\u02d4\u02d7\t\3\2\2\u02d5\u02d7\5\u009dO\2\u02d6\u02d2"+
"\3\2\2\2\u02d6\u02d3\3\2\2\2\u02d6\u02d4\3\2\2\2\u02d6\u02d5\3\2\2\2\u02d7"+
"\u02d8\3\2\2\2\u02d8\u02d6\3\2\2\2\u02d8\u02d9\3\2\2\2\u02d9\u00b2\3\2"+
"\2\2\u02da\u02e0\7$\2\2\u02db\u02df\n\5\2\2\u02dc\u02dd\7$\2\2\u02dd\u02df"+
"\7$\2\2\u02de\u02db\3\2\2\2\u02de\u02dc\3\2\2\2\u02df\u02e2\3\2\2\2\u02e0"+
"\u02de\3\2\2\2\u02e0\u02e1\3\2\2\2\u02e1\u02e3\3\2\2\2\u02e2\u02e0\3\2"+
"\2\2\u02e3\u02e4\7$\2\2\u02e4\u00b4\3\2\2\2\u02e5\u02eb\7b\2\2\u02e6\u02ea"+
"\n\6\2\2\u02e7\u02e8\7b\2\2\u02e8\u02ea\7b\2\2\u02e9\u02e6\3\2\2\2\u02e9"+
"\u02e7\3\2\2\2\u02ea\u02ed\3\2\2\2\u02eb\u02e9\3\2\2\2\u02eb\u02ec\3\2"+
"\2\2\u02ec\u02ee\3\2\2\2\u02ed\u02eb\3\2\2\2\u02ee\u02ef\7b\2\2\u02ef"+
"\u00b6\3\2\2\2\u02f0\u02f2\7G\2\2\u02f1\u02f3\t\7\2\2\u02f2\u02f1\3\2"+
"\2\2\u02f2\u02f3\3\2\2\2\u02f3\u02f5\3\2\2\2\u02f4\u02f6\5\u00b9]\2\u02f5"+
"\u02f4\3\2\2\2\u02f6\u02f7\3\2\2\2\u02f7\u02f5\3\2\2\2\u02f7\u02f8\3\2"+
"\2\2\u02f8\u00b8\3\2\2\2\u02f9\u02fa\t\b\2\2\u02fa\u00ba\3\2\2\2\u02fb"+
"\u02fc\t\t\2\2\u02fc\u00bc\3\2\2\2\u02fd\u02fe\7/\2\2\u02fe\u02ff\7/\2"+
"\2\u02ff\u0303\3\2\2\2\u0300\u0302\n\n\2\2\u0301\u0300\3\2\2\2\u0302\u0305"+
"\3\2\2\2\u0303\u0301\3\2\2\2\u0303\u0304\3\2\2\2\u0304\u0307\3\2\2\2\u0305"+
"\u0303\3\2\2\2\u0306\u0308\7\17\2\2\u0307\u0306\3\2\2\2\u0307\u0308\3"+
"\2\2\2\u0308\u030a\3\2\2\2\u0309\u030b\7\f\2\2\u030a\u0309\3\2\2\2\u030a"+
"\u030b\3\2\2\2\u030b\u030c\3\2\2\2\u030c\u030d\b_\2\2\u030d\u00be\3\2"+
"\2\2\u030e\u030f\7\61\2\2\u030f\u0310\7,\2\2\u0310\u0315\3\2\2\2\u0311"+
"\u0314\5\u00bf`\2\u0312\u0314\13\2\2\2\u0313\u0311\3\2\2\2\u0313\u0312"+
"\3\2\2\2\u0314\u0317\3\2\2\2\u0315\u0316\3\2\2\2\u0315\u0313\3\2\2\2\u0316"+
"\u0318\3\2\2\2\u0317\u0315\3\2\2\2\u0318\u0319\7,\2\2\u0319\u031a\7\61"+
"\2\2\u031a\u031b\3\2\2\2\u031b\u031c\b`\2\2\u031c\u00c0\3\2\2\2\u031d"+
"\u031f\t\13\2\2\u031e\u031d\3\2\2\2\u031f\u0320\3\2\2\2\u0320\u031e\3"+
"\2\2\2\u0320\u0321\3\2\2\2\u0321\u0322\3\2\2\2\u0322\u0323\ba\2\2\u0323"+
"\u00c2\3\2\2\2\u0324\u0325\13\2\2\2\u0325\u00c4\3\2\2\2\"\2\u0267\u0286"+
"\u0288\u0290\u0295\u029b\u02a2\u02a7\u02ad\u02b0\u02b8\u02bc\u02c0\u02c5"+
"\u02c7\u02ce\u02d0\u02d6\u02d8\u02de\u02e0\u02e9\u02eb\u02f2\u02f7\u0303"+
"\u0307\u030a\u0313\u0315\u0320\3\2\3\2";
"\2\2\u00b5\3\2\2\2\2\u00b7\3\2\2\2\2\u00b9\3\2\2\2\2\u00c1\3\2\2\2\2\u00c3"+
"\3\2\2\2\2\u00c5\3\2\2\2\2\u00c7\3\2\2\2\3\u00c9\3\2\2\2\5\u00cb\3\2\2"+
"\2\7\u00cd\3\2\2\2\t\u00cf\3\2\2\2\13\u00d1\3\2\2\2\r\u00d5\3\2\2\2\17"+
"\u00dd\3\2\2\2\21\u00e6\3\2\2\2\23\u00ea\3\2\2\2\25\u00ee\3\2\2\2\27\u00f1"+
"\3\2\2\2\31\u00f5\3\2\2\2\33\u00fd\3\2\2\2\35\u0100\3\2\2\2\37\u0105\3"+
"\2\2\2!\u010d\3\2\2\2#\u0116\3\2\2\2%\u011e\3\2\2\2\'\u0124\3\2\2\2)\u0129"+
"\3\2\2\2+\u0132\3\2\2\2-\u013b\3\2\2\2/\u0142\3\2\2\2\61\u014d\3\2\2\2"+
"\63\u0154\3\2\2\2\65\u015c\3\2\2\2\67\u0164\3\2\2\29\u016a\3\2\2\2;\u0171"+
"\3\2\2\2=\u0176\3\2\2\2?\u017b\3\2\2\2A\u0185\3\2\2\2C\u018e\3\2\2\2E"+
"\u0194\3\2\2\2G\u019b\3\2\2\2I\u019e\3\2\2\2K\u01a4\3\2\2\2M\u01a7\3\2"+
"\2\2O\u01ac\3\2\2\2Q\u01b1\3\2\2\2S\u01b6\3\2\2\2U\u01bc\3\2\2\2W\u01c3"+
"\3\2\2\2Y\u01c9\3\2\2\2[\u01d1\3\2\2\2]\u01d5\3\2\2\2_\u01da\3\2\2\2a"+
"\u01dd\3\2\2\2c\u01e7\3\2\2\2e\u01ea\3\2\2\2g\u01f0\3\2\2\2i\u01f6\3\2"+
"\2\2k\u01fd\3\2\2\2m\u0206\3\2\2\2o\u020b\3\2\2\2q\u0211\3\2\2\2s\u0217"+
"\3\2\2\2u\u021d\3\2\2\2w\u0225\3\2\2\2y\u022c\3\2\2\2{\u0231\3\2\2\2}"+
"\u0235\3\2\2\2\177\u023b\3\2\2\2\u0081\u0242\3\2\2\2\u0083\u0247\3\2\2"+
"\2\u0085\u024c\3\2\2\2\u0087\u0251\3\2\2\2\u0089\u0257\3\2\2\2\u008b\u025d"+
"\3\2\2\2\u008d\u0264\3\2\2\2\u008f\u026a\3\2\2\2\u0091\u026f\3\2\2\2\u0093"+
"\u0278\3\2\2\2\u0095\u027a\3\2\2\2\u0097\u027c\3\2\2\2\u0099\u027f\3\2"+
"\2\2\u009b\u0281\3\2\2\2\u009d\u0284\3\2\2\2\u009f\u0286\3\2\2\2\u00a1"+
"\u0288\3\2\2\2\u00a3\u028a\3\2\2\2\u00a5\u028c\3\2\2\2\u00a7\u028e\3\2"+
"\2\2\u00a9\u0291\3\2\2\2\u00ab\u0293\3\2\2\2\u00ad\u029f\3\2\2\2\u00af"+
"\u02cd\3\2\2\2\u00b1\u02d1\3\2\2\2\u00b3\u02db\3\2\2\2\u00b5\u02e7\3\2"+
"\2\2\u00b7\u02eb\3\2\2\2\u00b9\u02f6\3\2\2\2\u00bb\u0301\3\2\2\2\u00bd"+
"\u030a\3\2\2\2\u00bf\u030c\3\2\2\2\u00c1\u030e\3\2\2\2\u00c3\u031f\3\2"+
"\2\2\u00c5\u032f\3\2\2\2\u00c7\u0335\3\2\2\2\u00c9\u00ca\7*\2\2\u00ca"+
"\4\3\2\2\2\u00cb\u00cc\7+\2\2\u00cc\6\3\2\2\2\u00cd\u00ce\7.\2\2\u00ce"+
"\b\3\2\2\2\u00cf\u00d0\7<\2\2\u00d0\n\3\2\2\2\u00d1\u00d2\7C\2\2\u00d2"+
"\u00d3\7N\2\2\u00d3\u00d4\7N\2\2\u00d4\f\3\2\2\2\u00d5\u00d6\7C\2\2\u00d6"+
"\u00d7\7P\2\2\u00d7\u00d8\7C\2\2\u00d8\u00d9\7N\2\2\u00d9\u00da\7[\2\2"+
"\u00da\u00db\7\\\2\2\u00db\u00dc\7G\2\2\u00dc\16\3\2\2\2\u00dd\u00de\7"+
"C\2\2\u00de\u00df\7P\2\2\u00df\u00e0\7C\2\2\u00e0\u00e1\7N\2\2\u00e1\u00e2"+
"\7[\2\2\u00e2\u00e3\7\\\2\2\u00e3\u00e4\7G\2\2\u00e4\u00e5\7F\2\2\u00e5"+
"\20\3\2\2\2\u00e6\u00e7\7C\2\2\u00e7\u00e8\7P\2\2\u00e8\u00e9\7F\2\2\u00e9"+
"\22\3\2\2\2\u00ea\u00eb\7C\2\2\u00eb\u00ec\7P\2\2\u00ec\u00ed\7[\2\2\u00ed"+
"\24\3\2\2\2\u00ee\u00ef\7C\2\2\u00ef\u00f0\7U\2\2\u00f0\26\3\2\2\2\u00f1"+
"\u00f2\7C\2\2\u00f2\u00f3\7U\2\2\u00f3\u00f4\7E\2\2\u00f4\30\3\2\2\2\u00f5"+
"\u00f6\7D\2\2\u00f6\u00f7\7G\2\2\u00f7\u00f8\7V\2\2\u00f8\u00f9\7Y\2\2"+
"\u00f9\u00fa\7G\2\2\u00fa\u00fb\7G\2\2\u00fb\u00fc\7P\2\2\u00fc\32\3\2"+
"\2\2\u00fd\u00fe\7D\2\2\u00fe\u00ff\7[\2\2\u00ff\34\3\2\2\2\u0100\u0101"+
"\7E\2\2\u0101\u0102\7C\2\2\u0102\u0103\7U\2\2\u0103\u0104\7V\2\2\u0104"+
"\36\3\2\2\2\u0105\u0106\7E\2\2\u0106\u0107\7C\2\2\u0107\u0108\7V\2\2\u0108"+
"\u0109\7C\2\2\u0109\u010a\7N\2\2\u010a\u010b\7Q\2\2\u010b\u010c\7I\2\2"+
"\u010c \3\2\2\2\u010d\u010e\7E\2\2\u010e\u010f\7C\2\2\u010f\u0110\7V\2"+
"\2\u0110\u0111\7C\2\2\u0111\u0112\7N\2\2\u0112\u0113\7Q\2\2\u0113\u0114"+
"\7I\2\2\u0114\u0115\7U\2\2\u0115\"\3\2\2\2\u0116\u0117\7E\2\2\u0117\u0118"+
"\7Q\2\2\u0118\u0119\7N\2\2\u0119\u011a\7W\2\2\u011a\u011b\7O\2\2\u011b"+
"\u011c\7P\2\2\u011c\u011d\7U\2\2\u011d$\3\2\2\2\u011e\u011f\7F\2\2\u011f"+
"\u0120\7G\2\2\u0120\u0121\7D\2\2\u0121\u0122\7W\2\2\u0122\u0123\7I\2\2"+
"\u0123&\3\2\2\2\u0124\u0125\7F\2\2\u0125\u0126\7G\2\2\u0126\u0127\7U\2"+
"\2\u0127\u0128\7E\2\2\u0128(\3\2\2\2\u0129\u012a\7F\2\2\u012a\u012b\7"+
"G\2\2\u012b\u012c\7U\2\2\u012c\u012d\7E\2\2\u012d\u012e\7T\2\2\u012e\u012f"+
"\7K\2\2\u012f\u0130\7D\2\2\u0130\u0131\7G\2\2\u0131*\3\2\2\2\u0132\u0133"+
"\7F\2\2\u0133\u0134\7K\2\2\u0134\u0135\7U\2\2\u0135\u0136\7V\2\2\u0136"+
"\u0137\7K\2\2\u0137\u0138\7P\2\2\u0138\u0139\7E\2\2\u0139\u013a\7V\2\2"+
"\u013a,\3\2\2\2\u013b\u013c\7G\2\2\u013c\u013d\7U\2\2\u013d\u013e\7E\2"+
"\2\u013e\u013f\7C\2\2\u013f\u0140\7R\2\2\u0140\u0141\7G\2\2\u0141.\3\2"+
"\2\2\u0142\u0143\7G\2\2\u0143\u0144\7Z\2\2\u0144\u0145\7G\2\2\u0145\u0146"+
"\7E\2\2\u0146\u0147\7W\2\2\u0147\u0148\7V\2\2\u0148\u0149\7C\2\2\u0149"+
"\u014a\7D\2\2\u014a\u014b\7N\2\2\u014b\u014c\7G\2\2\u014c\60\3\2\2\2\u014d"+
"\u014e\7G\2\2\u014e\u014f\7Z\2\2\u014f\u0150\7K\2\2\u0150\u0151\7U\2\2"+
"\u0151\u0152\7V\2\2\u0152\u0153\7U\2\2\u0153\62\3\2\2\2\u0154\u0155\7"+
"G\2\2\u0155\u0156\7Z\2\2\u0156\u0157\7R\2\2\u0157\u0158\7N\2\2\u0158\u0159"+
"\7C\2\2\u0159\u015a\7K\2\2\u015a\u015b\7P\2\2\u015b\64\3\2\2\2\u015c\u015d"+
"\7G\2\2\u015d\u015e\7Z\2\2\u015e\u015f\7V\2\2\u015f\u0160\7T\2\2\u0160"+
"\u0161\7C\2\2\u0161\u0162\7E\2\2\u0162\u0163\7V\2\2\u0163\66\3\2\2\2\u0164"+
"\u0165\7H\2\2\u0165\u0166\7C\2\2\u0166\u0167\7N\2\2\u0167\u0168\7U\2\2"+
"\u0168\u0169\7G\2\2\u01698\3\2\2\2\u016a\u016b\7H\2\2\u016b\u016c\7Q\2"+
"\2\u016c\u016d\7T\2\2\u016d\u016e\7O\2\2\u016e\u016f\7C\2\2\u016f\u0170"+
"\7V\2\2\u0170:\3\2\2\2\u0171\u0172\7H\2\2\u0172\u0173\7T\2\2\u0173\u0174"+
"\7Q\2\2\u0174\u0175\7O\2\2\u0175<\3\2\2\2\u0176\u0177\7H\2\2\u0177\u0178"+
"\7W\2\2\u0178\u0179\7N\2\2\u0179\u017a\7N\2\2\u017a>\3\2\2\2\u017b\u017c"+
"\7H\2\2\u017c\u017d\7W\2\2\u017d\u017e\7P\2\2\u017e\u017f\7E\2\2\u017f"+
"\u0180\7V\2\2\u0180\u0181\7K\2\2\u0181\u0182\7Q\2\2\u0182\u0183\7P\2\2"+
"\u0183\u0184\7U\2\2\u0184@\3\2\2\2\u0185\u0186\7I\2\2\u0186\u0187\7T\2"+
"\2\u0187\u0188\7C\2\2\u0188\u0189\7R\2\2\u0189\u018a\7J\2\2\u018a\u018b"+
"\7X\2\2\u018b\u018c\7K\2\2\u018c\u018d\7\\\2\2\u018dB\3\2\2\2\u018e\u018f"+
"\7I\2\2\u018f\u0190\7T\2\2\u0190\u0191\7Q\2\2\u0191\u0192\7W\2\2\u0192"+
"\u0193\7R\2\2\u0193D\3\2\2\2\u0194\u0195\7J\2\2\u0195\u0196\7C\2\2\u0196"+
"\u0197\7X\2\2\u0197\u0198\7K\2\2\u0198\u0199\7P\2\2\u0199\u019a\7I\2\2"+
"\u019aF\3\2\2\2\u019b\u019c\7K\2\2\u019c\u019d\7P\2\2\u019dH\3\2\2\2\u019e"+
"\u019f\7K\2\2\u019f\u01a0\7P\2\2\u01a0\u01a1\7P\2\2\u01a1\u01a2\7G\2\2"+
"\u01a2\u01a3\7T\2\2\u01a3J\3\2\2\2\u01a4\u01a5\7K\2\2\u01a5\u01a6\7U\2"+
"\2\u01a6L\3\2\2\2\u01a7\u01a8\7L\2\2\u01a8\u01a9\7Q\2\2\u01a9\u01aa\7"+
"K\2\2\u01aa\u01ab\7P\2\2\u01abN\3\2\2\2\u01ac\u01ad\7N\2\2\u01ad\u01ae"+
"\7G\2\2\u01ae\u01af\7H\2\2\u01af\u01b0\7V\2\2\u01b0P\3\2\2\2\u01b1\u01b2"+
"\7N\2\2\u01b2\u01b3\7K\2\2\u01b3\u01b4\7M\2\2\u01b4\u01b5\7G\2\2\u01b5"+
"R\3\2\2\2\u01b6\u01b7\7N\2\2\u01b7\u01b8\7K\2\2\u01b8\u01b9\7O\2\2\u01b9"+
"\u01ba\7K\2\2\u01ba\u01bb\7V\2\2\u01bbT\3\2\2\2\u01bc\u01bd\7O\2\2\u01bd"+
"\u01be\7C\2\2\u01be\u01bf\7R\2\2\u01bf\u01c0\7R\2\2\u01c0\u01c1\7G\2\2"+
"\u01c1\u01c2\7F\2\2\u01c2V\3\2\2\2\u01c3\u01c4\7O\2\2\u01c4\u01c5\7C\2"+
"\2\u01c5\u01c6\7V\2\2\u01c6\u01c7\7E\2\2\u01c7\u01c8\7J\2\2\u01c8X\3\2"+
"\2\2\u01c9\u01ca\7P\2\2\u01ca\u01cb\7C\2\2\u01cb\u01cc\7V\2\2\u01cc\u01cd"+
"\7W\2\2\u01cd\u01ce\7T\2\2\u01ce\u01cf\7C\2\2\u01cf\u01d0\7N\2\2\u01d0"+
"Z\3\2\2\2\u01d1\u01d2\7P\2\2\u01d2\u01d3\7Q\2\2\u01d3\u01d4\7V\2\2\u01d4"+
"\\\3\2\2\2\u01d5\u01d6\7P\2\2\u01d6\u01d7\7W\2\2\u01d7\u01d8\7N\2\2\u01d8"+
"\u01d9\7N\2\2\u01d9^\3\2\2\2\u01da\u01db\7Q\2\2\u01db\u01dc\7P\2\2\u01dc"+
"`\3\2\2\2\u01dd\u01de\7Q\2\2\u01de\u01df\7R\2\2\u01df\u01e0\7V\2\2\u01e0"+
"\u01e1\7K\2\2\u01e1\u01e2\7O\2\2\u01e2\u01e3\7K\2\2\u01e3\u01e4\7\\\2"+
"\2\u01e4\u01e5\7G\2\2\u01e5\u01e6\7F\2\2\u01e6b\3\2\2\2\u01e7\u01e8\7"+
"Q\2\2\u01e8\u01e9\7T\2\2\u01e9d\3\2\2\2\u01ea\u01eb\7Q\2\2\u01eb\u01ec"+
"\7T\2\2\u01ec\u01ed\7F\2\2\u01ed\u01ee\7G\2\2\u01ee\u01ef\7T\2\2\u01ef"+
"f\3\2\2\2\u01f0\u01f1\7Q\2\2\u01f1\u01f2\7W\2\2\u01f2\u01f3\7V\2\2\u01f3"+
"\u01f4\7G\2\2\u01f4\u01f5\7T\2\2\u01f5h\3\2\2\2\u01f6\u01f7\7R\2\2\u01f7"+
"\u01f8\7C\2\2\u01f8\u01f9\7T\2\2\u01f9\u01fa\7U\2\2\u01fa\u01fb\7G\2\2"+
"\u01fb\u01fc\7F\2\2\u01fcj\3\2\2\2\u01fd\u01fe\7R\2\2\u01fe\u01ff\7J\2"+
"\2\u01ff\u0200\7[\2\2\u0200\u0201\7U\2\2\u0201\u0202\7K\2\2\u0202\u0203"+
"\7E\2\2\u0203\u0204\7C\2\2\u0204\u0205\7N\2\2\u0205l\3\2\2\2\u0206\u0207"+
"\7R\2\2\u0207\u0208\7N\2\2\u0208\u0209\7C\2\2\u0209\u020a\7P\2\2\u020a"+
"n\3\2\2\2\u020b\u020c\7T\2\2\u020c\u020d\7K\2\2\u020d\u020e\7I\2\2\u020e"+
"\u020f\7J\2\2\u020f\u0210\7V\2\2\u0210p\3\2\2\2\u0211\u0212\7T\2\2\u0212"+
"\u0213\7N\2\2\u0213\u0214\7K\2\2\u0214\u0215\7M\2\2\u0215\u0216\7G\2\2"+
"\u0216r\3\2\2\2\u0217\u0218\7S\2\2\u0218\u0219\7W\2\2\u0219\u021a\7G\2"+
"\2\u021a\u021b\7T\2\2\u021b\u021c\7[\2\2\u021ct\3\2\2\2\u021d\u021e\7"+
"U\2\2\u021e\u021f\7E\2\2\u021f\u0220\7J\2\2\u0220\u0221\7G\2\2\u0221\u0222"+
"\7O\2\2\u0222\u0223\7C\2\2\u0223\u0224\7U\2\2\u0224v\3\2\2\2\u0225\u0226"+
"\7U\2\2\u0226\u0227\7G\2\2\u0227\u0228\7N\2\2\u0228\u0229\7G\2\2\u0229"+
"\u022a\7E\2\2\u022a\u022b\7V\2\2\u022bx\3\2\2\2\u022c\u022d\7U\2\2\u022d"+
"\u022e\7J\2\2\u022e\u022f\7Q\2\2\u022f\u0230\7Y\2\2\u0230z\3\2\2\2\u0231"+
"\u0232\7U\2\2\u0232\u0233\7[\2\2\u0233\u0234\7U\2\2\u0234|\3\2\2\2\u0235"+
"\u0236\7V\2\2\u0236\u0237\7C\2\2\u0237\u0238\7D\2\2\u0238\u0239\7N\2\2"+
"\u0239\u023a\7G\2\2\u023a~\3\2\2\2\u023b\u023c\7V\2\2\u023c\u023d\7C\2"+
"\2\u023d\u023e\7D\2\2\u023e\u023f\7N\2\2\u023f\u0240\7G\2\2\u0240\u0241"+
"\7U\2\2\u0241\u0080\3\2\2\2\u0242\u0243\7V\2\2\u0243\u0244\7G\2\2\u0244"+
"\u0245\7Z\2\2\u0245\u0246\7V\2\2\u0246\u0082\3\2\2\2\u0247\u0248\7V\2"+
"\2\u0248\u0249\7T\2\2\u0249\u024a\7W\2\2\u024a\u024b\7G\2\2\u024b\u0084"+
"\3\2\2\2\u024c\u024d\7V\2\2\u024d\u024e\7[\2\2\u024e\u024f\7R\2\2\u024f"+
"\u0250\7G\2\2\u0250\u0086\3\2\2\2\u0251\u0252\7V\2\2\u0252\u0253\7[\2"+
"\2\u0253\u0254\7R\2\2\u0254\u0255\7G\2\2\u0255\u0256\7U\2\2\u0256\u0088"+
"\3\2\2\2\u0257\u0258\7W\2\2\u0258\u0259\7U\2\2\u0259\u025a\7K\2\2\u025a"+
"\u025b\7P\2\2\u025b\u025c\7I\2\2\u025c\u008a\3\2\2\2\u025d\u025e\7X\2"+
"\2\u025e\u025f\7G\2\2\u025f\u0260\7T\2\2\u0260\u0261\7K\2\2\u0261\u0262"+
"\7H\2\2\u0262\u0263\7[\2\2\u0263\u008c\3\2\2\2\u0264\u0265\7Y\2\2\u0265"+
"\u0266\7J\2\2\u0266\u0267\7G\2\2\u0267\u0268\7T\2\2\u0268\u0269\7G\2\2"+
"\u0269\u008e\3\2\2\2\u026a\u026b\7Y\2\2\u026b\u026c\7K\2\2\u026c\u026d"+
"\7V\2\2\u026d\u026e\7J\2\2\u026e\u0090\3\2\2\2\u026f\u0270\7?\2\2\u0270"+
"\u0092\3\2\2\2\u0271\u0272\7>\2\2\u0272\u0279\7@\2\2\u0273\u0274\7#\2"+
"\2\u0274\u0279\7?\2\2\u0275\u0276\7>\2\2\u0276\u0277\7?\2\2\u0277\u0279"+
"\7@\2\2\u0278\u0271\3\2\2\2\u0278\u0273\3\2\2\2\u0278\u0275\3\2\2\2\u0279"+
"\u0094\3\2\2\2\u027a\u027b\7>\2\2\u027b\u0096\3\2\2\2\u027c\u027d\7>\2"+
"\2\u027d\u027e\7?\2\2\u027e\u0098\3\2\2\2\u027f\u0280\7@\2\2\u0280\u009a"+
"\3\2\2\2\u0281\u0282\7@\2\2\u0282\u0283\7?\2\2\u0283\u009c\3\2\2\2\u0284"+
"\u0285\7-\2\2\u0285\u009e\3\2\2\2\u0286\u0287\7/\2\2\u0287\u00a0\3\2\2"+
"\2\u0288\u0289\7,\2\2\u0289\u00a2\3\2\2\2\u028a\u028b\7\61\2\2\u028b\u00a4"+
"\3\2\2\2\u028c\u028d\7\'\2\2\u028d\u00a6\3\2\2\2\u028e\u028f\7~\2\2\u028f"+
"\u0290\7~\2\2\u0290\u00a8\3\2\2\2\u0291\u0292\7\60\2\2\u0292\u00aa\3\2"+
"\2\2\u0293\u0299\7)\2\2\u0294\u0298\n\2\2\2\u0295\u0296\7)\2\2\u0296\u0298"+
"\7)\2\2\u0297\u0294\3\2\2\2\u0297\u0295\3\2\2\2\u0298\u029b\3\2\2\2\u0299"+
"\u0297\3\2\2\2\u0299\u029a\3\2\2\2\u029a\u029c\3\2\2\2\u029b\u0299\3\2"+
"\2\2\u029c\u029d\7)\2\2\u029d\u00ac\3\2\2\2\u029e\u02a0\5\u00bd_\2\u029f"+
"\u029e\3\2\2\2\u02a0\u02a1\3\2\2\2\u02a1\u029f\3\2\2\2\u02a1\u02a2\3\2"+
"\2\2\u02a2\u00ae\3\2\2\2\u02a3\u02a5\5\u00bd_\2\u02a4\u02a3\3\2\2\2\u02a5"+
"\u02a6\3\2\2\2\u02a6\u02a4\3\2\2\2\u02a6\u02a7\3\2\2\2\u02a7\u02a8\3\2"+
"\2\2\u02a8\u02ac\5\u00a9U\2\u02a9\u02ab\5\u00bd_\2\u02aa\u02a9\3\2\2\2"+
"\u02ab\u02ae\3\2\2\2\u02ac\u02aa\3\2\2\2\u02ac\u02ad\3\2\2\2\u02ad\u02ce"+
"\3\2\2\2\u02ae\u02ac\3\2\2\2\u02af\u02b1\5\u00a9U\2\u02b0\u02b2\5\u00bd"+
"_\2\u02b1\u02b0\3\2\2\2\u02b2\u02b3\3\2\2\2\u02b3\u02b1\3\2\2\2\u02b3"+
"\u02b4\3\2\2\2\u02b4\u02ce\3\2\2\2\u02b5\u02b7\5\u00bd_\2\u02b6\u02b5"+
"\3\2\2\2\u02b7\u02b8\3\2\2\2\u02b8\u02b6\3\2\2\2\u02b8\u02b9\3\2\2\2\u02b9"+
"\u02c1\3\2\2\2\u02ba\u02be\5\u00a9U\2\u02bb\u02bd\5\u00bd_\2\u02bc\u02bb"+
"\3\2\2\2\u02bd\u02c0\3\2\2\2\u02be\u02bc\3\2\2\2\u02be\u02bf\3\2\2\2\u02bf"+
"\u02c2\3\2\2\2\u02c0\u02be\3\2\2\2\u02c1\u02ba\3\2\2\2\u02c1\u02c2\3\2"+
"\2\2\u02c2\u02c3\3\2\2\2\u02c3\u02c4\5\u00bb^\2\u02c4\u02ce\3\2\2\2\u02c5"+
"\u02c7\5\u00a9U\2\u02c6\u02c8\5\u00bd_\2\u02c7\u02c6\3\2\2\2\u02c8\u02c9"+
"\3\2\2\2\u02c9\u02c7\3\2\2\2\u02c9\u02ca\3\2\2\2\u02ca\u02cb\3\2\2\2\u02cb"+
"\u02cc\5\u00bb^\2\u02cc\u02ce\3\2\2\2\u02cd\u02a4\3\2\2\2\u02cd\u02af"+
"\3\2\2\2\u02cd\u02b6\3\2\2\2\u02cd\u02c5\3\2\2\2\u02ce\u00b0\3\2\2\2\u02cf"+
"\u02d2\5\u00bf`\2\u02d0\u02d2\7a\2\2\u02d1\u02cf\3\2\2\2\u02d1\u02d0\3"+
"\2\2\2\u02d2\u02d8\3\2\2\2\u02d3\u02d7\5\u00bf`\2\u02d4\u02d7\5\u00bd"+
"_\2\u02d5\u02d7\t\3\2\2\u02d6\u02d3\3\2\2\2\u02d6\u02d4\3\2\2\2\u02d6"+
"\u02d5\3\2\2\2\u02d7\u02da\3\2\2\2\u02d8\u02d6\3\2\2\2\u02d8\u02d9\3\2"+
"\2\2\u02d9\u00b2\3\2\2\2\u02da\u02d8\3\2\2\2\u02db\u02df\5\u00bd_\2\u02dc"+
"\u02e0\5\u00bf`\2\u02dd\u02e0\5\u00bd_\2\u02de\u02e0\t\4\2\2\u02df\u02dc"+
"\3\2\2\2\u02df\u02dd\3\2\2\2\u02df\u02de\3\2\2\2\u02e0\u02e1\3\2\2\2\u02e1"+
"\u02df\3\2\2\2\u02e1\u02e2\3\2\2\2\u02e2\u00b4\3\2\2\2\u02e3\u02e8\5\u00bf"+
"`\2\u02e4\u02e8\5\u00bd_\2\u02e5\u02e8\t\3\2\2\u02e6\u02e8\5\u00a1Q\2"+
"\u02e7\u02e3\3\2\2\2\u02e7\u02e4\3\2\2\2\u02e7\u02e5\3\2\2\2\u02e7\u02e6"+
"\3\2\2\2\u02e8\u02e9\3\2\2\2\u02e9\u02e7\3\2\2\2\u02e9\u02ea\3\2\2\2\u02ea"+
"\u00b6\3\2\2\2\u02eb\u02f1\7$\2\2\u02ec\u02f0\n\5\2\2\u02ed\u02ee\7$\2"+
"\2\u02ee\u02f0\7$\2\2\u02ef\u02ec\3\2\2\2\u02ef\u02ed\3\2\2\2\u02f0\u02f3"+
"\3\2\2\2\u02f1\u02ef\3\2\2\2\u02f1\u02f2\3\2\2\2\u02f2\u02f4\3\2\2\2\u02f3"+
"\u02f1\3\2\2\2\u02f4\u02f5\7$\2\2\u02f5\u00b8\3\2\2\2\u02f6\u02fc\7b\2"+
"\2\u02f7\u02fb\n\6\2\2\u02f8\u02f9\7b\2\2\u02f9\u02fb\7b\2\2\u02fa\u02f7"+
"\3\2\2\2\u02fa\u02f8\3\2\2\2\u02fb\u02fe\3\2\2\2\u02fc\u02fa\3\2\2\2\u02fc"+
"\u02fd\3\2\2\2\u02fd\u02ff\3\2\2\2\u02fe\u02fc\3\2\2\2\u02ff\u0300\7b"+
"\2\2\u0300\u00ba\3\2\2\2\u0301\u0303\7G\2\2\u0302\u0304\t\7\2\2\u0303"+
"\u0302\3\2\2\2\u0303\u0304\3\2\2\2\u0304\u0306\3\2\2\2\u0305\u0307\5\u00bd"+
"_\2\u0306\u0305\3\2\2\2\u0307\u0308\3\2\2\2\u0308\u0306\3\2\2\2\u0308"+
"\u0309\3\2\2\2\u0309\u00bc\3\2\2\2\u030a\u030b\t\b\2\2\u030b\u00be\3\2"+
"\2\2\u030c\u030d\t\t\2\2\u030d\u00c0\3\2\2\2\u030e\u030f\7/\2\2\u030f"+
"\u0310\7/\2\2\u0310\u0314\3\2\2\2\u0311\u0313\n\n\2\2\u0312\u0311\3\2"+
"\2\2\u0313\u0316\3\2\2\2\u0314\u0312\3\2\2\2\u0314\u0315\3\2\2\2\u0315"+
"\u0318\3\2\2\2\u0316\u0314\3\2\2\2\u0317\u0319\7\17\2\2\u0318\u0317\3"+
"\2\2\2\u0318\u0319\3\2\2\2\u0319\u031b\3\2\2\2\u031a\u031c\7\f\2\2\u031b"+
"\u031a\3\2\2\2\u031b\u031c\3\2\2\2\u031c\u031d\3\2\2\2\u031d\u031e\ba"+
"\2\2\u031e\u00c2\3\2\2\2\u031f\u0320\7\61\2\2\u0320\u0321\7,\2\2\u0321"+
"\u0326\3\2\2\2\u0322\u0325\5\u00c3b\2\u0323\u0325\13\2\2\2\u0324\u0322"+
"\3\2\2\2\u0324\u0323\3\2\2\2\u0325\u0328\3\2\2\2\u0326\u0327\3\2\2\2\u0326"+
"\u0324\3\2\2\2\u0327\u0329\3\2\2\2\u0328\u0326\3\2\2\2\u0329\u032a\7,"+
"\2\2\u032a\u032b\7\61\2\2\u032b\u032c\3\2\2\2\u032c\u032d\bb\2\2\u032d"+
"\u00c4\3\2\2\2\u032e\u0330\t\13\2\2\u032f\u032e\3\2\2\2\u0330\u0331\3"+
"\2\2\2\u0331\u032f\3\2\2\2\u0331\u0332\3\2\2\2\u0332\u0333\3\2\2\2\u0333"+
"\u0334\bc\2\2\u0334\u00c6\3\2\2\2\u0335\u0336\13\2\2\2\u0336\u00c8\3\2"+
"\2\2\"\2\u0278\u0297\u0299\u02a1\u02a6\u02ac\u02b3\u02b8\u02be\u02c1\u02c9"+
"\u02cd\u02d1\u02d6\u02d8\u02df\u02e1\u02e7\u02e9\u02ef\u02f1\u02fa\u02fc"+
"\u0303\u0308\u0314\u0318\u031b\u0324\u0326\u0331\3\2\3\2";
public static final ATN _ATN =
new ATNDeserializer().deserialize(_serializedATN.toCharArray());
static {

View File

@ -116,18 +116,6 @@ interface SqlBaseListener extends ParseTreeListener {
* @param ctx the parse tree
*/
void exitShowSchemas(SqlBaseParser.ShowSchemasContext ctx);
/**
* Enter a parse tree produced by the {@code sysCatalogs}
* labeled alternative in {@link SqlBaseParser#statement}.
* @param ctx the parse tree
*/
void enterSysCatalogs(SqlBaseParser.SysCatalogsContext ctx);
/**
* Exit a parse tree produced by the {@code sysCatalogs}
* labeled alternative in {@link SqlBaseParser#statement}.
* @param ctx the parse tree
*/
void exitSysCatalogs(SqlBaseParser.SysCatalogsContext ctx);
/**
* Enter a parse tree produced by the {@code sysTables}
* labeled alternative in {@link SqlBaseParser#statement}.

View File

@ -76,13 +76,6 @@ interface SqlBaseVisitor<T> extends ParseTreeVisitor<T> {
* @return the visitor result
*/
T visitShowSchemas(SqlBaseParser.ShowSchemasContext ctx);
/**
* Visit a parse tree produced by the {@code sysCatalogs}
* labeled alternative in {@link SqlBaseParser#statement}.
* @param ctx the parse tree
* @return the visitor result
*/
T visitSysCatalogs(SqlBaseParser.SysCatalogsContext ctx);
/**
* Visit a parse tree produced by the {@code sysTables}
* labeled alternative in {@link SqlBaseParser#statement}.

View File

@ -47,7 +47,7 @@ public class ShowTables extends Command {
public final void execute(SqlSession session, ActionListener<SchemaRowSet> listener) {
String index = pattern != null ? pattern.asIndexNameWildcard() : "*";
String regex = pattern != null ? pattern.asJavaRegex() : null;
session.indexResolver().resolveNames(index, regex, ActionListener.wrap(result -> {
session.indexResolver().resolveNames(index, regex, null, ActionListener.wrap(result -> {
listener.onResponse(Rows.of(output(), result.stream()
.map(t -> asList(t.name(), t.type().toSql()))
.collect(toList())));

View File

@ -6,6 +6,7 @@
package org.elasticsearch.xpack.sql.plan.logical.command.sys;
import org.elasticsearch.action.ActionListener;
import org.elasticsearch.xpack.sql.analysis.index.IndexResolver.IndexType;
import org.elasticsearch.xpack.sql.expression.Attribute;
import org.elasticsearch.xpack.sql.expression.regex.LikePattern;
import org.elasticsearch.xpack.sql.plan.logical.command.Command;
@ -15,8 +16,10 @@ import org.elasticsearch.xpack.sql.session.SqlSession;
import org.elasticsearch.xpack.sql.tree.Location;
import org.elasticsearch.xpack.sql.tree.NodeInfo;
import java.util.EnumSet;
import java.util.List;
import java.util.Objects;
import java.util.regex.Pattern;
import static java.util.Arrays.asList;
import static java.util.stream.Collectors.toList;
@ -25,24 +28,24 @@ import static org.elasticsearch.xpack.sql.util.StringUtils.EMPTY;
public class SysTables extends Command {
private final LikePattern pattern;
private final LikePattern clusterPattern;
private final EnumSet<IndexType> types;
public SysTables(Location location, LikePattern pattern) {
public SysTables(Location location, LikePattern clusterPattern, LikePattern pattern, EnumSet<IndexType> types) {
super(location);
this.clusterPattern = clusterPattern;
this.pattern = pattern;
this.types = types;
}
@Override
protected NodeInfo<SysTables> info() {
return NodeInfo.create(this, SysTables::new, pattern);
}
public LikePattern pattern() {
return pattern;
return NodeInfo.create(this, SysTables::new, clusterPattern, pattern, types);
}
@Override
public List<Attribute> output() {
return asList(keyword("TABLE_CAT"),
return asList(keyword("TABLE_CAT"),
keyword("TABLE_SCHEM"),
keyword("TABLE_NAME"),
keyword("TABLE_TYPE"),
@ -57,15 +60,24 @@ public class SysTables extends Command {
@Override
public final void execute(SqlSession session, ActionListener<SchemaRowSet> listener) {
String cluster = session.indexResolver().clusterName();
String cRegex = clusterPattern != null ? clusterPattern.asJavaRegex() : null;
// if the catalog doesn't match, don't return any results
if (cRegex != null && !Pattern.matches(cRegex, cluster)) {
listener.onResponse(Rows.empty(output()));
return;
}
String index = pattern != null ? pattern.asIndexNameWildcard() : "*";
String regex = pattern != null ? pattern.asJavaRegex() : null;
String cluster = session.indexResolver().clusterName();
session.indexResolver().resolveNames(index, regex, ActionListener.wrap(result -> listener.onResponse(
session.indexResolver().resolveNames(index, regex, types, ActionListener.wrap(result -> listener.onResponse(
Rows.of(output(), result.stream()
.map(t -> asList(cluster,
EMPTY,
t.name(),
t.name(),
t.type().toSql(),
EMPTY,
null,
@ -79,7 +91,7 @@ public class SysTables extends Command {
@Override
public int hashCode() {
return Objects.hash(pattern);
return Objects.hash(clusterPattern, pattern, types);
}
@Override
@ -93,6 +105,8 @@ public class SysTables extends Command {
}
SysTables other = (SysTables) obj;
return Objects.equals(pattern, other.pattern);
return Objects.equals(clusterPattern, other.clusterPattern)
&& Objects.equals(pattern, other.pattern)
&& Objects.equals(types, other.types);
}
}

View File

@ -71,20 +71,20 @@ public class SysParserTests extends ESTestCase {
}, ex -> fail(ex.getMessage())));
}
public void testSysColsNoArgs(String commandVariation) throws Exception {
public void testSysColsNoArgs() throws Exception {
runSysColumns("SYS COLUMNS");
}
public void testSysColsTableOnlyPattern(String commandVariation) throws Exception {
runSysColumns("SYS COLUMNS TABLES LIKE 'test'");
public void testSysColsTableOnlyPattern() throws Exception {
runSysColumns("SYS COLUMNS TABLE LIKE 'test'");
}
public void testSysColsColOnlyPattern(String commandVariation) throws Exception {
public void testSysColsColOnlyPattern() throws Exception {
runSysColumns("SYS COLUMNS LIKE '%'");
}
public void testSysColsTableAndColsPattern(String commandVariation) throws Exception {
runSysColumns("SYS COLUMNS TABLES LIKE 'test' LIKE '%'");
public void testSysColsTableAndColsPattern() throws Exception {
runSysColumns("SYS COLUMNS TABLE LIKE 'test' LIKE '%'");
}
@ -95,6 +95,7 @@ public class SysParserTests extends ESTestCase {
"text",
"keyword",
"unsupported",
"date",
"some",
"some.dotted",
"some.dotted.field",
@ -114,7 +115,7 @@ public class SysParserTests extends ESTestCase {
sql.v1().execute(sql.v2(), ActionListener.wrap(r -> {
assertEquals(24, r.columnCount());
assertEquals(21, r.size());
assertEquals(22, r.size());
for (int i = 0; i < r.size(); i++) {
assertEquals("cluster", r.column(0));

View File

@ -0,0 +1,123 @@
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License;
* you may not use this file except in compliance with the Elastic License.
*/
package org.elasticsearch.xpack.sql.plan.logical.command.sys;
import org.elasticsearch.action.ActionListener;
import org.elasticsearch.common.collect.Tuple;
import org.elasticsearch.test.ESTestCase;
import org.elasticsearch.xpack.sql.analysis.analyzer.Analyzer;
import org.elasticsearch.xpack.sql.analysis.index.EsIndex;
import org.elasticsearch.xpack.sql.analysis.index.IndexResolution;
import org.elasticsearch.xpack.sql.analysis.index.IndexResolver;
import org.elasticsearch.xpack.sql.analysis.index.IndexResolver.IndexInfo;
import org.elasticsearch.xpack.sql.analysis.index.IndexResolver.IndexType;
import org.elasticsearch.xpack.sql.expression.function.FunctionRegistry;
import org.elasticsearch.xpack.sql.parser.ParsingException;
import org.elasticsearch.xpack.sql.parser.SqlParser;
import org.elasticsearch.xpack.sql.plan.logical.command.Command;
import org.elasticsearch.xpack.sql.session.SchemaRowSet;
import org.elasticsearch.xpack.sql.session.SqlSession;
import org.elasticsearch.xpack.sql.type.EsField;
import org.elasticsearch.xpack.sql.type.TypesTests;
import org.joda.time.DateTimeZone;
import java.util.LinkedHashSet;
import java.util.Map;
import java.util.function.Consumer;
import static java.util.Arrays.asList;
import static org.elasticsearch.action.ActionListener.wrap;
import static org.mockito.Matchers.any;
import static org.mockito.Mockito.doAnswer;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
public class SysTablesTests extends ESTestCase {
private final SqlParser parser = new SqlParser(DateTimeZone.UTC);
private final Map<String, EsField> mapping = TypesTests.loadMapping("mapping-multi-field-with-nested.json", true);
private final IndexInfo index = new IndexInfo("test", IndexType.INDEX);
private final IndexInfo alias = new IndexInfo("alias", IndexType.ALIAS);
public void testSysTablesDifferentCatalog() throws Exception {
executeCommand("SYS TABLES CATALOG LIKE 'foo'", r -> {
assertEquals(0, r.size());
assertFalse(r.hasCurrentRow());
});
}
public void testSysTablesNoTypes() throws Exception {
executeCommand("SYS TABLES", r -> {
assertEquals(2, r.size());
assertEquals("test", r.column(2));
assertTrue(r.advanceRow());
assertEquals("alias", r.column(2));
}, index, alias);
}
public void testSysTablesPattern() throws Exception {
executeCommand("SYS TABLES LIKE '%'", r -> {
assertEquals(2, r.size());
assertEquals("test", r.column(2));
assertTrue(r.advanceRow());
assertEquals("alias", r.column(2));
}, index, alias);
}
public void testSysTablesOnlyAliases() throws Exception {
executeCommand("SYS TABLES LIKE 'test' TYPE 'ALIAS'", r -> {
assertEquals(1, r.size());
assertEquals("alias", r.column(2));
}, alias);
}
public void testSysTablesOnlyIndices() throws Exception {
executeCommand("SYS TABLES LIKE 'test' TYPE 'BASE TABLE'", r -> {
assertEquals(1, r.size());
assertEquals("test", r.column(2));
}, index);
}
public void testSysTablesOnlyIndicesAndAliases() throws Exception {
executeCommand("SYS TABLES LIKE 'test' TYPE 'ALIAS', 'BASE TABLE'", r -> {
assertEquals(2, r.size());
assertEquals("test", r.column(2));
assertTrue(r.advanceRow());
assertEquals("alias", r.column(2));
}, index, alias);
}
public void testSysTablesWithInvalidType() throws Exception {
ParsingException pe = expectThrows(ParsingException.class, () -> sql("SYS TABLES LIKE 'test' TYPE 'QUE HORA ES'"));
assertEquals("line 1:2: Invalid table type [QUE HORA ES]", pe.getMessage());
}
private Tuple<Command, SqlSession> sql(String sql) {
EsIndex test = new EsIndex("test", mapping);
Analyzer analyzer = new Analyzer(new FunctionRegistry(), IndexResolution.valid(test), DateTimeZone.UTC);
Command cmd = (Command) analyzer.analyze(parser.createStatement(sql), true);
IndexResolver resolver = mock(IndexResolver.class);
when(resolver.clusterName()).thenReturn("cluster");
SqlSession session = new SqlSession(null, null, null, resolver, null, null, null);
return new Tuple<>(cmd, session);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
private void executeCommand(String sql, Consumer<SchemaRowSet> consumer, IndexInfo... infos) throws Exception {
Tuple<Command, SqlSession> tuple = sql(sql);
IndexResolver resolver = tuple.v2().indexResolver();
doAnswer(invocation -> {
((ActionListener) invocation.getArguments()[3]).onResponse(new LinkedHashSet<>(asList(infos)));
return Void.TYPE;
}).when(resolver).resolveNames(any(), any(), any(), any());
tuple.v1().execute(tuple.v2(), wrap(consumer::accept, ex -> fail(ex.getMessage())));
}
}

View File

@ -39,6 +39,7 @@ import java.nio.file.SimpleFileVisitor;
import java.nio.file.attribute.BasicFileAttributes;
import java.util.ArrayList;
import java.util.Collection;
import java.util.EnumSet;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@ -155,8 +156,9 @@ public class NodeSubclassTests<T extends B, B extends Node<B>> extends ESTestCas
Type changedArgType = argTypes[changedArgOffset];
if (originalArgValue instanceof Collection) {
List<?> originalList = (List<?>) originalArgValue;
if (originalList.isEmpty()) {
Collection<?> col = (Collection<?>) originalArgValue;
if (col.isEmpty() || col instanceof EnumSet) {
/*
* We skip empty lists here because they'll spuriously
* pass the conditions below if statements even if they don't
@ -168,6 +170,9 @@ public class NodeSubclassTests<T extends B, B extends Node<B>> extends ESTestCas
continue;
}
List<?> originalList = (List<?>) originalArgValue;
if (node.children().equals(originalList)) {
// The arg we're looking at *is* the children
@SuppressWarnings("unchecked") // we pass a reasonable type so get reasonable results
@ -332,6 +337,7 @@ public class NodeSubclassTests<T extends B, B extends Node<B>> extends ESTestCas
/**
* Make an argument to feed to the constructor for {@code toBuildClass}.
*/
@SuppressWarnings("unchecked")
private static Object makeArg(Class<? extends Node<?>> toBuildClass, Type argType) throws Exception {
if (argType instanceof ParameterizedType) {
ParameterizedType pt = (ParameterizedType) argType;
@ -348,6 +354,11 @@ public class NodeSubclassTests<T extends B, B extends Node<B>> extends ESTestCas
if (pt.getRawType() == List.class) {
return makeList(toBuildClass, pt, between(1, 10));
}
if (pt.getRawType() == EnumSet.class) {
@SuppressWarnings("rawtypes")
Enum enm = (Enum) makeArg(toBuildClass, pt.getActualTypeArguments()[0]);
return EnumSet.of(enm);
}
if (pt.getRawType() == Supplier.class) {
if (toBuildClass == AggValueInput.class) {
// AggValueInput just needs a valid java type in a supplier
@ -455,7 +466,7 @@ public class NodeSubclassTests<T extends B, B extends Node<B>> extends ESTestCas
}
if (argClass.isEnum()) {
// Can't mock enums but luckilly we can just pick one
// Can't mock enums but luckily we can just pick one
return randomFrom(argClass.getEnumConstants());
}
if (argClass == boolean.class) {