Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix type hint bug in eval_const_expr_partial() (issue #39548) #39812

Closed
wants to merge 2 commits into from
Closed
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 12 additions & 4 deletions src/librustc_const_eval/eval.rs
Original file line number Diff line number Diff line change
Expand Up @@ -519,15 +519,23 @@ fn eval_const_expr_partial<'a, 'tcx>(cx: &ConstContext<'a, 'tcx>,
}
hir::ExprUnary(hir::UnDeref, _) => signal!(e, UnimplementedConstVal("deref operation")),
hir::ExprBinary(op, ref a, ref b) => {
let b_ty = match op.node {
hir::BiShl | hir::BiShr => ty_hint.erase_hint(),
_ => ty_hint
// Use the same type hint for the operands as for the whole
// expression, except when the operation is a shift, in which
// case we use no type hint for the RHS, and when the operation
// is a comparison, in which case we use no type hint for
// either operand.
let (a_ty, b_ty) = match op.node {
hir::BiShl | hir::BiShr => (ty_hint, ty_hint.erase_hint()),
hir::BiEq | hir::BiLe | hir::BiLt |
hir::BiNe | hir::BiGe | hir::BiGt =>
(ty_hint.erase_hint(), ty_hint.erase_hint()),
_ => (ty_hint, ty_hint)
};
// technically, if we don't have type hints, but integral eval
// gives us a type through a type-suffix, cast or const def type
// we need to re-eval the other value of the BinOp if it was
// not inferred
match (cx.eval(a, ty_hint)?,
match (cx.eval(a, a_ty)?,
cx.eval(b, b_ty)?) {
(Float(a), Float(b)) => {
use std::cmp::Ordering::*;
Expand Down