summary refs log tree commit diff
path: root/src/test/ui/proc-macro/span-preservation.rs
blob: 64f675ecc1c4d1f3579e1eaff60cdc52ab3341cc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
//~ ERROR mismatched types
// aux-build:span-preservation.rs

// For each of these, we should get the appropriate type mismatch error message,
// and the function should be echoed.

extern crate span_preservation as foo;

use foo::foo;

#[foo]
fn a() {
    let x: usize = "hello";;;;; //~ ERROR mismatched types
}

#[foo]
fn b(x: Option<isize>) -> usize {
    match x {
        Some(x) => { return x }, //~ ERROR mismatched types
        None => 10
    }
}

#[foo]
fn c() {
    struct Foo {
        a: usize
    }

    struct Bar {
        a: usize,
        b: usize
    }

    let x = Foo { a: 10isize }; //~ ERROR mismatched types
    let y = Foo { a: 10, b: 10isize }; //~ ERROR has no field named `b`
}

// FIXME: This doesn't work at the moment. See the one below. The pretty-printer
// injects a "C" between `extern` and `fn` which causes a "probably_eq"
// `TokenStream` mismatch. The lack of `"C"` should be preserved in the AST.
#[foo]
extern fn bar() {
    0
}

#[foo]
extern "C" fn baz() {
    0 //~ ERROR mismatched types
}

fn main() {}