Document why some "type mismatches" exist

This commit is contained in:
Oli Scherer 2024-12-05 20:16:48 +00:00
parent 8df89d1cb0
commit 476074888f

View File

@ -1619,6 +1619,9 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
ast::LitKind::Int(_, ast::LitIntType::Unsuffixed) => {
let opt_ty = expected.to_option(self).and_then(|ty| match ty.kind() {
ty::Int(_) | ty::Uint(_) => Some(ty),
// These exist to direct casts like `0x61 as char` to use
// the right integer type to cast from, instead of falling back to
// i32 due to no further constraints.
ty::Char => Some(tcx.types.u8),
ty::RawPtr(..) => Some(tcx.types.usize),
ty::FnDef(..) | ty::FnPtr(..) => Some(tcx.types.usize),