[
https://issues.apache.org/jira/browse/CALCITE-1695?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Julian Hyde resolved CALCITE-1695.
----------------------------------
Resolution: Fixed
Fixed in http://git-wip-us.apache.org/repos/asf/calcite/commit/ca48431e. Added
{{class RexSimplify}}, providing an explicit {{RexExecutor}} for methods to
simplify {{RexNode}}s. The {{RexUtil.simplifyXxx}} methods that were present in
release 1.11 are still present but are deprecated.
> Not all RexUtil.simplifyXxx code paths carry the provided executor
> ------------------------------------------------------------------
>
> Key: CALCITE-1695
> URL: https://issues.apache.org/jira/browse/CALCITE-1695
> Project: Calcite
> Issue Type: Bug
> Reporter: Remus Rusanu
> Assignee: Remus Rusanu
> Fix For: 1.12.0
>
>
> CALCITE-1653 resolved some of the issues encountered with different semantics
> in Hive executor vs. Calcite default executor. When investigating a
> workaround for CALCITE-1690 I found that there are other code paths that can
> this the same issue, eg:
> {noformat}
> at org.apache.calcite.rex.RexBuilder.makeLiteral(RexBuilder.java:1239)
> at org.apache.calcite.rex.RexBuilder.makeLiteral(RexBuilder.java:1236)
> at org.apache.calcite.rex.RexExecutable.reduce(RexExecutable.java:86)
> at
> org.apache.calcite.rex.RexExecutorImpl.reduce(RexExecutorImpl.java:128)
> at org.apache.calcite.rex.RexUtil.simplifyCast(RexUtil.java:2450)
> at org.apache.calcite.rex.RexUtil.simplify(RexUtil.java:1633)
> at org.apache.calcite.rex.RexUtil.simplify(RexUtil.java:1587)
> at org.apache.calcite.rex.RexUtil.simplifyList(RexUtil.java:1747)
> at org.apache.calcite.rex.RexUtil.simplifyComparison(RexUtil.java:1658)
> at org.apache.calcite.rex.RexUtil.simplify(RexUtil.java:1648)
> at
> org.apache.calcite.rex.RexUtil$ExprSimplifier.visitCall(RexUtil.java:3051)
> at
> org.apache.calcite.rex.RexUtil$ExprSimplifier.visitCall(RexUtil.java:3016)
> at org.apache.calcite.rex.RexCall.accept(RexCall.java:104)
> at org.apache.calcite.rex.RexShuttle.apply(RexShuttle.java:279)
> at
> org.apache.calcite.rel.rules.ReduceExpressionsRule.reduceExpressions(ReduceExpressionsRule.java:473)
> {noformat}
> Int he stack above neither {{RexUtil.simplifyComparison}} nor
> {{RexUtil.simplifyList}} accept an executor, and thus the executor info
> present at the {{RexUtil.simplify:1648}} frame is lost and the default
> {{EXECUTOR}} is used instead. The result is incorrect for Hive.
--
This message was sent by Atlassian JIRA
(v6.3.15#6346)