2015-02-24 11:34:39 -06:00
|
|
|
// Issue 22443: Reject code using non-regular types that would
|
|
|
|
// otherwise cause dropck to loop infinitely.
|
|
|
|
//
|
|
|
|
// This version is just checking that we still sanely handle a trivial
|
|
|
|
// wrapper around the non-regular type. (It also demonstrates how the
|
|
|
|
// error messages will report different types depending on which type
|
|
|
|
// dropck is analyzing.)
|
|
|
|
|
|
|
|
use std::marker::PhantomData;
|
|
|
|
|
|
|
|
struct Digit<T> {
|
|
|
|
elem: T
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Node<T:'static> { m: PhantomData<&'static T> }
|
|
|
|
|
|
|
|
enum FingerTree<T:'static> {
|
|
|
|
Single(T),
|
|
|
|
// According to the bug report, Digit before Box would infinite loop.
|
|
|
|
Deep(
|
|
|
|
Digit<T>,
|
|
|
|
Box<FingerTree<Node<T>>>,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
enum Wrapper<T:'static> {
|
|
|
|
Simple,
|
|
|
|
Other(FingerTree<T>),
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
2020-09-02 02:40:56 -05:00
|
|
|
let w = //~ ERROR overflow while adding drop-check rules for Option
|
2015-02-24 11:34:39 -06:00
|
|
|
Some(Wrapper::Simple::<u32>);
|
2022-06-28 15:56:32 -05:00
|
|
|
//~^ ERROR overflow while adding drop-check rules for Wrapper
|
2015-02-24 11:34:39 -06:00
|
|
|
}
|