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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
// xfail-pretty
use std;
use rustc;
import rustc::*;
import io::*;
import rustc::driver::diagnostic;
import rustc::syntax::ast;
import rustc::syntax::codemap;
import rustc::syntax::parse::parser;
import rustc::syntax::print::*;
fn new_parse_sess() -> parser::parse_sess {
let cm = codemap::new_codemap();
let handler = diagnostic::mk_handler(option::none);
let sess = @{
cm: cm,
mut next_id: 1,
span_diagnostic: diagnostic::mk_span_handler(handler, cm),
mut chpos: 0u,
mut byte_pos: 0u
};
ret sess;
}
iface fake_ext_ctxt {
fn cfg() -> ast::crate_cfg;
fn parse_sess() -> parser::parse_sess;
}
type fake_session = ();
impl of fake_ext_ctxt for fake_session {
fn cfg() -> ast::crate_cfg { [] }
fn parse_sess() -> parser::parse_sess { new_parse_sess() }
}
fn mk_ctxt() -> fake_ext_ctxt {
() as fake_ext_ctxt
}
fn main() {
let ext_cx = mk_ctxt();
let abc = #ast{23};
check_pp(abc, pprust::print_expr, "23");
let expr3 = #ast{2 - $(abc) + 7};
check_pp(expr3, pprust::print_expr, "2 - 23 + 7");
let expr4 = #ast{2 - $(#ast{3}) + 9};
check_pp(expr4, pprust::print_expr, "2 - 3 + 9");
let ty = #ast(ty){int};
check_pp(ty, pprust::print_type, "int");
let ty2 = #ast(ty){option<$(ty)>};
check_pp(ty2, pprust::print_type, "option<int>");
let item = #ast(item){const x : int = 10;};
check_pp(item, pprust::print_item, "const x: int = 10;");
let item2: @ast::item = #ast(item){const x : int = $(abc);};
check_pp(item2, pprust::print_item, "const x: int = 23;");
let stmt = #ast(stmt){let x = 20;};
check_pp(*stmt, pprust::print_stmt, "let x = 20;");
let stmt2 = #ast(stmt){let x : $(ty) = $(abc);};
check_pp(*stmt2, pprust::print_stmt, "let x: int = 23;");
let pat = #ast(pat){some(_)};
check_pp(pat, pprust::print_pat, "some(_)");
// issue #1785
let x = #ast{1};
let test1 = #ast{1+$(x)};
check_pp(test1, pprust::print_expr, "1 + 1");
let test2 = #ast{$(x)+1};
check_pp(test2, pprust::print_expr, "1 + 1");
let y = #ast{2};
let test3 = #ast{$(x) + $(y)};
check_pp(test3, pprust::print_expr, "1 + 2");
let crate = #ast(crate) { fn a() { } };
check_pp(crate, pprust::print_crate_, "fn a() { }\n");
// issue #1926
let s = #ast(expr){__s};
let e = #ast(expr){__e};
let call = #ast(expr){$(s).foo {|__e| $(e)}};
check_pp(call, pprust::print_expr, "__s.foo {|__e| __e }")
}
fn check_pp<T>(expr: T, f: fn(pprust::ps, T), expect: str) {
let buf = mem_buffer();
let pp = pprust::rust_printer(buf as io::writer);
f(pp, expr);
pp::eof(pp.s);
let str = mem_buffer_str(buf);
stdout().write_line(str);
if expect != "" {
#error("expect: '%s', got: '%s'", expect, str);
assert str == expect;
}
}
|