Skip to content

Commit

Permalink
Updated grammar for FILLNULL to match grammar in SQL project (#968)
Browse files Browse the repository at this point in the history
Signed-off-by: Norman Jordan <[email protected]>
  • Loading branch information
normanj-bitquill authored Dec 6, 2024
1 parent 63222a7 commit bda109c
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 18 deletions.
19 changes: 7 additions & 12 deletions ppl-spark-integration/src/main/antlr4/OpenSearchPPLParser.g4
Original file line number Diff line number Diff line change
Expand Up @@ -237,21 +237,16 @@ fillnullCommand
| fillNullWithFieldVariousValues)
;

fillNullWithTheSameValue
: WITH nullReplacement IN nullableField (COMMA nullableField)*
;

fillNullWithFieldVariousValues
: USING nullableField EQUAL nullReplacement (COMMA nullableField EQUAL nullReplacement)*
;

fillNullWithTheSameValue
: WITH nullReplacement = valueExpression IN nullableFieldList = fieldList
;

nullableField
: fieldExpression
fillNullWithFieldVariousValues
: USING nullableReplacementExpression (COMMA nullableReplacementExpression)*
;

nullReplacement
: expression
nullableReplacementExpression
: nullableField = fieldExpression EQUAL nullableReplacement = valueExpression
;

expandCommand
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -581,19 +581,18 @@ public UnresolvedPlan visitFillnullCommand(OpenSearchPPLParser.FillnullCommandCo
FillNullWithFieldVariousValuesContext variousValuesContext = ctx.fillNullWithFieldVariousValues();
if (sameValueContext != null) {
// todo consider using expression instead of Literal
UnresolvedExpression replaceNullWithMe = internalVisitExpression(sameValueContext.nullReplacement().expression());
List<Field> fieldsToReplace = sameValueContext.nullableField()
UnresolvedExpression replaceNullWithMe = internalVisitExpression(sameValueContext.nullReplacement);
List<Field> fieldsToReplace = sameValueContext.nullableFieldList.fieldExpression()
.stream()
.map(this::internalVisitExpression)
.map(Field.class::cast)
.collect(Collectors.toList());
return new FillNull(ofSameValue(replaceNullWithMe, fieldsToReplace));
} else if (variousValuesContext != null) {
List<NullableFieldFill> nullableFieldFills = IntStream.range(0, variousValuesContext.nullableField().size())
List<NullableFieldFill> nullableFieldFills = IntStream.range(0, variousValuesContext.nullableReplacementExpression().size())
.mapToObj(index -> {
variousValuesContext.nullableField(index);
UnresolvedExpression replaceNullWithMe = internalVisitExpression(variousValuesContext.nullReplacement(index).expression());
Field nullableFieldReference = (Field) internalVisitExpression(variousValuesContext.nullableField(index));
UnresolvedExpression replaceNullWithMe = internalVisitExpression(variousValuesContext.nullableReplacementExpression(index).nullableReplacement);
Field nullableFieldReference = (Field) internalVisitExpression(variousValuesContext.nullableReplacementExpression(index).nullableField);
return new NullableFieldFill(nullableFieldReference, replaceNullWithMe);
})
.collect(Collectors.toList());
Expand Down

0 comments on commit bda109c

Please sign in to comment.