diff options
| author | bors <bors@rust-lang.org> | 2017-05-09 09:27:50 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2017-05-09 09:27:50 +0000 |
| commit | c2d53dce7eaef554a6c48eb5f179884becee4d82 (patch) | |
| tree | aea2bfb3f925ffbeec831ace13b6e6322be4591d /src/test | |
| parent | bedd7da3d28d69520f33ac6a585df87ef1373a26 (diff) | |
| parent | cadf18734707d62529f0174f8e77c9d46457b1cf (diff) | |
| download | rust-c2d53dce7eaef554a6c48eb5f179884becee4d82.tar.gz rust-c2d53dce7eaef554a6c48eb5f179884becee4d82.zip | |
Auto merge of #41777 - nikomatsakis:issue-41697-mir-dump-cycle, r=arielb1
dump-mir was causing cycles by invoking item-path-str at bad times Workaround for now, but probably a better fix is to opt **in** to using the types for impls (if we do that at all; maybe filename/line is better). Fixes #41697
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/run-pass/issue-41697.rs | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/src/test/run-pass/issue-41697.rs b/src/test/run-pass/issue-41697.rs new file mode 100644 index 00000000000..d59b6a16562 --- /dev/null +++ b/src/test/run-pass/issue-41697.rs @@ -0,0 +1,50 @@ +// Copyright 2016 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// compile-flags:-Zdump-mir=NEVER_MATCHED + +// 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 +// an attempt to get the item-path, which in turn would request the +// types of the impl, which would trigger a cycle. We supressed this +// 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]; +} + +impl Foo for [u8; 2] { + 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]); +} |
