Skip to content

Commit ca30c67

Browse files
committed
transmutability: only short-circuit is_transmutable for non-region infers
1 parent e22dab3 commit ca30c67

3 files changed

Lines changed: 36 additions & 1 deletion

File tree

compiler/rustc_transmute/src/lib.rs

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -89,7 +89,7 @@ pub enum Reason<T> {
8989
#[cfg(feature = "rustc")]
9090
mod rustc {
9191
use rustc_hir::lang_items::LangItem;
92-
use rustc_middle::ty::{Const, Region, Ty, TyCtxt};
92+
use rustc_middle::ty::{Const, Region, Ty, TyCtxt, TypeVisitableExt};
9393

9494
use super::*;
9595

@@ -116,6 +116,10 @@ mod rustc {
116116
types: Types<'tcx>,
117117
assume: crate::Assume,
118118
) -> crate::Answer<Region<'tcx>, Ty<'tcx>> {
119+
if types.src.has_non_region_infer() || types.dst.has_non_region_infer() {
120+
return Answer::No(Reason::TypeError);
121+
}
122+
119123
crate::maybe_transmutable::MaybeTransmutableQuery::new(
120124
types.src, types.dst, assume, self.tcx,
121125
)
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
#![feature(transmutability)]
2+
trait OpaqueTrait {}
3+
4+
impl<T: std::mem::TransmuteFrom<(), ()>> OpaqueTrait for T {}
5+
//~^ ERROR: type provided when a constant was expected
6+
7+
impl<T> OpaqueTrait for &T where T: OpaqueTrait {}
8+
//~^ ERROR: conflicting implementations of trait `OpaqueTrait` for type `&_`
9+
10+
fn main() {}
Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
error[E0747]: type provided when a constant was expected
2+
--> $DIR/ice-141400-transmutability-coherence.rs:4:37
3+
|
4+
LL | impl<T: std::mem::TransmuteFrom<(), ()>> OpaqueTrait for T {}
5+
| ^^
6+
7+
error[E0119]: conflicting implementations of trait `OpaqueTrait` for type `&_`
8+
--> $DIR/ice-141400-transmutability-coherence.rs:7:1
9+
|
10+
LL | impl<T: std::mem::TransmuteFrom<(), ()>> OpaqueTrait for T {}
11+
| ---------------------------------------------------------- first implementation here
12+
...
13+
LL | impl<T> OpaqueTrait for &T where T: OpaqueTrait {}
14+
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ conflicting implementation for `&_`
15+
|
16+
= note: downstream crates may implement trait `std::mem::TransmuteFrom<(), std::mem::Assume { alignment: false, lifetimes: false, safety: false, validity: false }>` for type `&_`
17+
18+
error: aborting due to 2 previous errors
19+
20+
Some errors have detailed explanations: E0119, E0747.
21+
For more information about an error, try `rustc --explain E0119`.

0 commit comments

Comments
 (0)