From 3b4a57e2d3e93a8ace75739bee08c3070ec13ad2 Mon Sep 17 00:00:00 2001 From: Tomoyuki Morita Date: Fri, 19 Jul 2024 17:05:51 -0700 Subject: [PATCH] Remove unimplemented syntax Signed-off-by: Tomoyuki Morita --- .../src/main/antlr4/OpenSearchPPLParser.g4 | 29 +---------- .../opensearch/sql/ppl/parser/AstBuilder.java | 10 ++-- .../sql/ppl/parser/AstExpressionBuilder.java | 49 ------------------- 3 files changed, 7 insertions(+), 81 deletions(-) diff --git a/ppl-spark-integration/src/main/antlr4/OpenSearchPPLParser.g4 b/ppl-spark-integration/src/main/antlr4/OpenSearchPPLParser.g4 index 4b4e64c1a..0d9b4e64e 100644 --- a/ppl-spark-integration/src/main/antlr4/OpenSearchPPLParser.g4 +++ b/ppl-spark-integration/src/main/antlr4/OpenSearchPPLParser.g4 @@ -37,18 +37,8 @@ commands | fieldsCommand | renameCommand | statsCommand - | dedupCommand | sortCommand - | evalCommand | headCommand - | topCommand - | rareCommand - | grokCommand - | parseCommand - | patternsCommand - | kmeansCommand - | adCommand - | mlCommand ; searchCommand @@ -190,8 +180,6 @@ mlArg fromClause : SOURCE EQUAL tableSourceClause | INDEX EQUAL tableSourceClause - | SOURCE EQUAL tableFunction - | INDEX EQUAL tableFunction ; tableSourceClause @@ -281,24 +269,17 @@ logicalExpression comparisonExpression : left = valueExpression comparisonOperator right = valueExpression # compareExpr - | valueExpression IN valueList # inExpr ; valueExpression : left = valueExpression binaryOperator = (STAR | DIVIDE | MODULE) right = valueExpression # binaryArithmetic | left = valueExpression binaryOperator = (PLUS | MINUS) right = valueExpression # binaryArithmetic | primaryExpression # valueExpressionDefault - | positionFunction # positionFunctionCall - | extractFunction # extractFunctionCall - | getFormatFunction # getFormatFunctionCall - | timestampFunction # timestampFunctionCall | LT_PRTHS valueExpression RT_PRTHS # parentheticValueExpr ; primaryExpression - : evalFunctionCall - | dataTypeFunctionCall - | fieldExpression + : fieldExpression | literalValue ; @@ -700,8 +681,7 @@ multiFieldRelevanceFunctionName // literals and values literalValue - : intervalLiteral - | stringLiteral + : stringLiteral | integerLiteral | decimalLiteral | booleanLiteral @@ -830,13 +810,8 @@ keywordsCanBeId : D // OD SQL and ODBC special | timespanUnit | SPAN - | evalFunctionName | relevanceArgName | intervalUnit - | dateTimeFunctionName - | textFunctionName - | mathematicalFunctionName - | positionFunctionName // commands | SEARCH | DESCRIBE diff --git a/ppl-spark-integration/src/main/java/org/opensearch/sql/ppl/parser/AstBuilder.java b/ppl-spark-integration/src/main/java/org/opensearch/sql/ppl/parser/AstBuilder.java index a810ea180..7719339e8 100644 --- a/ppl-spark-integration/src/main/java/org/opensearch/sql/ppl/parser/AstBuilder.java +++ b/ppl-spark-integration/src/main/java/org/opensearch/sql/ppl/parser/AstBuilder.java @@ -287,11 +287,11 @@ public UnresolvedPlan visitTopCommand(OpenSearchPPLParser.TopCommandContext ctx) /** From clause. */ @Override public UnresolvedPlan visitFromClause(OpenSearchPPLParser.FromClauseContext ctx) { - if (ctx.tableFunction() != null) { - return visitTableFunction(ctx.tableFunction()); - } else { - return visitTableSourceClause(ctx.tableSourceClause()); - } +// if (ctx.tableFunction() != null) { +// return visitTableFunction(ctx.tableFunction()); +// } else { + return visitTableSourceClause(ctx.tableSourceClause()); +// } } @Override diff --git a/ppl-spark-integration/src/main/java/org/opensearch/sql/ppl/parser/AstExpressionBuilder.java b/ppl-spark-integration/src/main/java/org/opensearch/sql/ppl/parser/AstExpressionBuilder.java index b265047b5..047d9af44 100644 --- a/ppl-spark-integration/src/main/java/org/opensearch/sql/ppl/parser/AstExpressionBuilder.java +++ b/ppl-spark-integration/src/main/java/org/opensearch/sql/ppl/parser/AstExpressionBuilder.java @@ -244,55 +244,6 @@ public UnresolvedExpression visitPositionFunction( Arrays.asList(visitFunctionArg(ctx.functionArg(0)), visitFunctionArg(ctx.functionArg(1)))); } - @Override - public UnresolvedExpression visitExtractFunctionCall( - OpenSearchPPLParser.ExtractFunctionCallContext ctx) { - return new Function( - ctx.extractFunction().EXTRACT().toString(), getExtractFunctionArguments(ctx)); - } - - private List getExtractFunctionArguments( - OpenSearchPPLParser.ExtractFunctionCallContext ctx) { - List args = - Arrays.asList( - new Literal(ctx.extractFunction().datetimePart().getText(), DataType.STRING), - visitFunctionArg(ctx.extractFunction().functionArg())); - return args; - } - - @Override - public UnresolvedExpression visitGetFormatFunctionCall( - OpenSearchPPLParser.GetFormatFunctionCallContext ctx) { - return new Function( - ctx.getFormatFunction().GET_FORMAT().toString(), getFormatFunctionArguments(ctx)); - } - - private List getFormatFunctionArguments( - OpenSearchPPLParser.GetFormatFunctionCallContext ctx) { - List args = - Arrays.asList( - new Literal(ctx.getFormatFunction().getFormatType().getText(), DataType.STRING), - visitFunctionArg(ctx.getFormatFunction().functionArg())); - return args; - } - - @Override - public UnresolvedExpression visitTimestampFunctionCall( - OpenSearchPPLParser.TimestampFunctionCallContext ctx) { - return new Function( - ctx.timestampFunction().timestampFunctionName().getText(), timestampFunctionArguments(ctx)); - } - - private List timestampFunctionArguments( - OpenSearchPPLParser.TimestampFunctionCallContext ctx) { - List args = - Arrays.asList( - new Literal(ctx.timestampFunction().simpleDateTimePart().getText(), DataType.STRING), - visitFunctionArg(ctx.timestampFunction().firstArg), - visitFunctionArg(ctx.timestampFunction().secondArg)); - return args; - } - /** * Literal and value. */