Rollup merge of #68236 - JohnTitor:ice-tests, r=Centril
Add some regression tests Closes #64848 (fixed by #67631) Closes #65918 (ICE is hidden by #67000, no longer ICE) Closes #66473 (fixed by #68084) Closes #67550 (set mir-opt-level to 3) r? @Centril
This commit is contained in:
commit
2039d7ee49
5 changed files with 79 additions and 0 deletions
|
@ -1,5 +1,6 @@
|
|||
// ignore-tidy-linelength
|
||||
// ignore-wasm32-bare compiled with panic=abort by default
|
||||
// compile-flags: -Z mir-opt-level=3
|
||||
#![feature(box_syntax)]
|
||||
|
||||
fn main() {
|
||||
|
|
29
src/test/ui/associated-types/issue-64848.rs
Normal file
29
src/test/ui/associated-types/issue-64848.rs
Normal file
|
@ -0,0 +1,29 @@
|
|||
// build-pass
|
||||
|
||||
trait AssociatedConstant {
|
||||
const DATA: ();
|
||||
}
|
||||
|
||||
impl<F, T> AssociatedConstant for F
|
||||
where
|
||||
F: FnOnce() -> T,
|
||||
T: AssociatedConstant,
|
||||
{
|
||||
const DATA: () = T::DATA;
|
||||
}
|
||||
|
||||
impl AssociatedConstant for () {
|
||||
const DATA: () = ();
|
||||
}
|
||||
|
||||
fn foo() -> impl AssociatedConstant {
|
||||
()
|
||||
}
|
||||
|
||||
fn get_data<T: AssociatedConstant>(_: T) -> &'static () {
|
||||
&T::DATA
|
||||
}
|
||||
|
||||
fn main() {
|
||||
get_data(foo);
|
||||
}
|
BIN
src/test/ui/issues/issue-66473.rs
Normal file
BIN
src/test/ui/issues/issue-66473.rs
Normal file
Binary file not shown.
BIN
src/test/ui/issues/issue-66473.stderr
Normal file
BIN
src/test/ui/issues/issue-66473.stderr
Normal file
Binary file not shown.
49
src/test/ui/type-alias-impl-trait/issue-65918.rs
Normal file
49
src/test/ui/type-alias-impl-trait/issue-65918.rs
Normal file
|
@ -0,0 +1,49 @@
|
|||
// build-pass
|
||||
|
||||
#![feature(type_alias_impl_trait)]
|
||||
|
||||
use std::marker::PhantomData;
|
||||
|
||||
/* copied Index and TryFrom for convinience (and simplicity) */
|
||||
trait MyIndex<T> {
|
||||
type O;
|
||||
fn my_index(self) -> Self::O;
|
||||
}
|
||||
trait MyFrom<T>: Sized {
|
||||
type Error;
|
||||
fn my_from(value: T) -> Result<Self, Self::Error>;
|
||||
}
|
||||
|
||||
/* MCVE starts here */
|
||||
trait F {}
|
||||
impl F for () {}
|
||||
type DummyT<T> = impl F;
|
||||
fn _dummy_t<T>() -> DummyT<T> {}
|
||||
|
||||
struct Phantom1<T>(PhantomData<T>);
|
||||
struct Phantom2<T>(PhantomData<T>);
|
||||
struct Scope<T>(Phantom2<DummyT<T>>);
|
||||
|
||||
impl<T> Scope<T> {
|
||||
fn new() -> Self {
|
||||
unimplemented!()
|
||||
}
|
||||
}
|
||||
|
||||
impl<T> MyFrom<Phantom2<T>> for Phantom1<T> {
|
||||
type Error = ();
|
||||
fn my_from(_: Phantom2<T>) -> Result<Self, Self::Error> {
|
||||
unimplemented!()
|
||||
}
|
||||
}
|
||||
|
||||
impl<T: MyFrom<Phantom2<DummyT<U>>>, U> MyIndex<Phantom1<T>> for Scope<U> {
|
||||
type O = T;
|
||||
fn my_index(self) -> Self::O {
|
||||
MyFrom::my_from(self.0).ok().unwrap()
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let _pos: Phantom1<DummyT<()>> = Scope::new().my_index();
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue