summaryrefslogtreecommitdiffstats
path: root/tests/ui/coercion/retslot-cast.rs
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() {}