Skip to content

Commit

Permalink
fix: potential fix for decimal template error
Browse files Browse the repository at this point in the history
Signed-off-by: Andrew Coleman <[email protected]>
  • Loading branch information
andrew-coleman authored and Blizzara committed Sep 19, 2024
1 parent 67f24d7 commit c13dddd
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 0 deletions.
10 changes: 10 additions & 0 deletions core/src/main/java/io/substrait/type/parser/ParseToPojo.java
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,16 @@ public TypeExpression visitDecimal(final SubstraitTypeParser.DecimalContext ctx)
return withNullP(nullable).decimalE((String) precision, (String) scale);
}

if (precision instanceof String && scale instanceof Integer) {
checkParameterizedOrExpression();
return withNullP(nullable).decimalE((String) precision, String.valueOf(scale));
}

if (precision instanceof Integer && scale instanceof String) {
checkParameterizedOrExpression();
return withNullP(nullable).decimalE(String.valueOf(precision), (String) scale);
}

checkExpression();
return withNullE(nullable).decimalE(ctx.precision.accept(this), ctx.scale.accept(this));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -119,6 +119,9 @@ private <T> void parameterizedTests(ParseToPojo.Visitor v) {
test(v, pn.listE(pr.parameter("any")), "list?<any>");
test(v, pn.listE(pn.parameter("any")), "list?<any?>");
test(v, pn.structE(r.I8, r.I16, n.I8, pr.parameter("K")), "STRUCT?<i8, i16, i8?, K>");
test(v, pr.decimalE("P", "S"), "DECIMAL<P, S>");
test(v, pr.decimalE("P", "0"), "DECIMAL<P, 0>");
test(v, pr.decimalE("14", "S"), "DECIMAL<14, S>");
}

private static void test(ParseToPojo.Visitor visitor, TypeExpression expected, String toParse) {
Expand Down

0 comments on commit c13dddd

Please sign in to comment.