2017-05-06 01:13:44 +00:00
|
|
|
// Regression test for #41697. Using dump-mir was triggering
|
|
|
|
// artificial cycles: during type-checking, we had to get the MIR for
|
|
|
|
// the constant expressions in `[u8; 2]`, which in turn would trigger
|
2018-12-19 10:31:35 +00:00
|
|
|
// an attempt to get the def-path, which in turn would request the
|
2017-11-21 14:33:45 +00:00
|
|
|
// types of the impl, which would trigger a cycle. We suppressed this
|
2017-05-06 01:13:44 +00:00
|
|
|
// cycle now by forcing mir-dump to avoid asking for types of an impl.
|
|
|
|
|
|
|
|
#![feature(rustc_attrs)]
|
|
|
|
|
|
|
|
use std::sync::Arc;
|
|
|
|
|
|
|
|
trait Foo {
|
|
|
|
fn get(&self) -> [u8; 2];
|
|
|
|
}
|
|
|
|
|
2020-04-04 20:25:54 +00:00
|
|
|
// EMIT_MIR_FOR_EACH_BIT_WIDTH
|
2020-07-27 19:22:43 +00:00
|
|
|
// EMIT_MIR issue_41697.{{impl}}-{{constant}}.SimplifyCfg-qualify-consts.after.mir
|
2020-04-02 21:09:01 +00:00
|
|
|
impl Foo for [u8; 1+1] {
|
2017-05-06 01:13:44 +00:00
|
|
|
fn get(&self) -> [u8; 2] {
|
|
|
|
*self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Bar<T: ?Sized>(T);
|
|
|
|
|
|
|
|
fn unsize_fat_ptr<'a>(x: &'a Bar<Foo + Send + 'a>) -> &'a Bar<Foo + 'a> {
|
|
|
|
x
|
|
|
|
}
|
|
|
|
|
|
|
|
fn unsize_nested_fat_ptr(x: Arc<Foo + Send>) -> Arc<Foo> {
|
|
|
|
x
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let x: Box<Bar<Foo + Send>> = Box::new(Bar([1,2]));
|
|
|
|
assert_eq!(unsize_fat_ptr(&*x).0.get(), [1, 2]);
|
|
|
|
|
|
|
|
let x: Arc<Foo + Send> = Arc::new([3, 4]);
|
|
|
|
assert_eq!(unsize_nested_fat_ptr(x).get(), [3, 4]);
|
|
|
|
}
|