andygrove opened a new issue, #1350:
URL: https://github.com/apache/datafusion-comet/issues/1350

   ### Describe the bug
   
   In `QueryPlanSerde`, we have code in `exprToProto` to ensure the decimal 
precision is the same for both children of a binary expression.
   
   ```scala
     def exprToProto(
         expr: Expression,
         inputs: Seq[Attribute],
         binding: Boolean = true): Option[Expr] = {
   
       val conf = SQLConf.get
       val newExpr =
         DecimalPrecision.promote(conf.decimalOperationsAllowPrecisionLoss, 
expr, !conf.ansiEnabled)
       exprToProtoInternal(newExpr, inputs, binding)
     }
   ```
   
   However, this calls `exprToProtoInternal` which is a recursive method. For 
example, when creating a binary expression:
   
   ```scala
       val leftExpr = exprToProtoInternal(left, inputs, binding)
       val rightExpr = exprToProtoInternal(right, inputs, binding)
   ```
   
   The decimal promotion logic is not applied in this case.
   
   Given that `exprToProto` contains a single line of code and then delegates 
to `exprToProtoInternal`, I propose that we simply combine these two methods.
   
   ### Steps to reproduce
   
   _No response_
   
   ### Expected behavior
   
   _No response_
   
   ### Additional context
   
   _No response_


-- 
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: github-unsubscr...@datafusion.apache.org.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


---------------------------------------------------------------------
To unsubscribe, e-mail: github-unsubscr...@datafusion.apache.org
For additional commands, e-mail: github-h...@datafusion.apache.org

Reply via email to