blob: ae500cb15dfdd813d29855954edfdc0e2ec4ccfa (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
#![allow(warnings)]
pub fn fail(x: Option<&(Iterator<Item=()>+Send)>)
-> Option<&Iterator<Item=()>> {
// This call used to trigger an LLVM assertion because the return
// slot had type "Option<&Iterator>"* instead of
// "Option<&(Iterator+Send)>"* -- but this now yields a
// compilation error and I'm not sure how to create a comparable
// test. To ensure that this PARTICULAR failure doesn't occur
// again, though, I've left this test here, so if this ever starts
// to compile again, we can adjust the test appropriately (clearly
// it should never ICE...). -nmatsakis
inner(x) //~ ERROR mismatched types
}
pub fn inner(x: Option<&(Iterator<Item=()>+Send)>)
-> Option<&(Iterator<Item=()>+Send)> {
x
}
fn main() {}
|