siddharthteotia commented on code in PR #9389: URL: https://github.com/apache/pinot/pull/9389#discussion_r972571348
########## pinot-common/src/main/java/org/apache/pinot/common/request/context/ExpressionContext.java: ########## @@ -31,41 +33,58 @@ */ public class ExpressionContext { public enum Type { - LITERAL, IDENTIFIER, FUNCTION + LITERAL, IDENTIFIER, FUNCTION, } private final Type _type; - private final String _value; + private final String _identifier; private final FunctionContext _function; + // Only set when the _type is LITERAL + private final LiteralContext _literal; - public static ExpressionContext forLiteral(String literal) { - return new ExpressionContext(Type.LITERAL, literal, null); + public static ExpressionContext forLiteralContext(Literal literal){ + return new ExpressionContext(Type.LITERAL, null, null, new LiteralContext(literal)); + } + + public static ExpressionContext forLiteralContext(FieldSpec.DataType type, Object val){ + return new ExpressionContext(Type.LITERAL, null, null, new LiteralContext(type, val)); } public static ExpressionContext forIdentifier(String identifier) { - return new ExpressionContext(Type.IDENTIFIER, identifier, null); + return new ExpressionContext(Type.IDENTIFIER, identifier, null, null); } public static ExpressionContext forFunction(FunctionContext function) { - return new ExpressionContext(Type.FUNCTION, null, function); + return new ExpressionContext(Type.FUNCTION, null, function, null); } - private ExpressionContext(Type type, String value, FunctionContext function) { + private ExpressionContext(Type type, String value, FunctionContext function, LiteralContext literal) { _type = type; - _value = value; + _identifier = value; _function = function; + _literal = literal; + } + + // TODO: Refactor all of the usage for getLiteralString. + @Deprecated + public String getLiteralString() { Review Comment: We should not add this imo. Quite a few places will have to be refactored later -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: commits-unsubscr...@pinot.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org --------------------------------------------------------------------- To unsubscribe, e-mail: commits-unsubscr...@pinot.apache.org For additional commands, e-mail: commits-h...@pinot.apache.org