Skip to content

Commit 179ce39

Browse files
committed
Fix and reenable the reflect-visit-type test
1 parent 469f394 commit 179ce39

File tree

1 file changed

+96
-85
lines changed

1 file changed

+96
-85
lines changed

src/test/run-pass/reflect-visit-type.rs

Lines changed: 96 additions & 85 deletions
Original file line numberDiff line numberDiff line change
@@ -8,151 +8,162 @@
88
// option. This file may not be copied, modified, or distributed
99
// except according to those terms.
1010

11-
// xfail-test
12-
use intrinsic::{TyDesc, get_tydesc, visit_tydesc, TyVisitor};
13-
struct my_visitor(@mut { types: ~[str] });
11+
use std::unstable::intrinsics::{TyDesc, get_tydesc, visit_tydesc, TyVisitor, Opaque};
1412

15-
impl TyVisitor for my_visitor {
16-
fn visit_bot() -> bool {
17-
self.types += ~["bot"];
13+
struct MyVisitor {
14+
types: @mut ~[~str],
15+
}
16+
17+
impl TyVisitor for MyVisitor {
18+
fn visit_bot(&self) -> bool {
19+
self.types.push(~"bot");
1820
error!("visited bot type");
1921
true
2022
}
21-
fn visit_nil() -> bool {
22-
self.types += ~["nil"];
23+
fn visit_nil(&self) -> bool {
24+
self.types.push(~"nil");
2325
error!("visited nil type");
2426
true
2527
}
26-
fn visit_bool() -> bool {
27-
self.types += ~["bool"];
28+
fn visit_bool(&self) -> bool {
29+
self.types.push(~"bool");
2830
error!("visited bool type");
2931
true
3032
}
31-
fn visit_int() -> bool {
32-
self.types += ~["int"];
33+
fn visit_int(&self) -> bool {
34+
self.types.push(~"int");
3335
error!("visited int type");
3436
true
3537
}
36-
fn visit_i8() -> bool {
37-
self.types += ~["i8"];
38+
fn visit_i8(&self) -> bool {
39+
self.types.push(~"i8");
3840
error!("visited i8 type");
3941
true
4042
}
41-
fn visit_i16() -> bool {
42-
self.types += ~["i16"];
43+
fn visit_i16(&self) -> bool {
44+
self.types.push(~"i16");
4345
error!("visited i16 type");
4446
true
4547
}
46-
fn visit_i32() -> bool { true }
47-
fn visit_i64() -> bool { true }
48-
49-
fn visit_uint() -> bool { true }
50-
fn visit_u8() -> bool { true }
51-
fn visit_u16() -> bool { true }
52-
fn visit_u32() -> bool { true }
53-
fn visit_u64() -> bool { true }
54-
55-
fn visit_float() -> bool { true }
56-
fn visit_f32() -> bool { true }
57-
fn visit_f64() -> bool { true }
58-
59-
fn visit_char() -> bool { true }
60-
fn visit_str() -> bool { true }
61-
62-
fn visit_estr_box() -> bool { true }
63-
fn visit_estr_uniq() -> bool { true }
64-
fn visit_estr_slice() -> bool { true }
65-
fn visit_estr_fixed(_sz: uint, _sz: uint,
48+
fn visit_i32(&self) -> bool { true }
49+
fn visit_i64(&self) -> bool { true }
50+
51+
fn visit_uint(&self) -> bool { true }
52+
fn visit_u8(&self) -> bool { true }
53+
fn visit_u16(&self) -> bool { true }
54+
fn visit_u32(&self) -> bool { true }
55+
fn visit_u64(&self) -> bool { true }
56+
57+
fn visit_float(&self) -> bool { true }
58+
fn visit_f32(&self) -> bool { true }
59+
fn visit_f64(&self) -> bool { true }
60+
61+
fn visit_char(&self) -> bool { true }
62+
fn visit_str(&self) -> bool { true }
63+
64+
fn visit_estr_box(&self) -> bool { true }
65+
fn visit_estr_uniq(&self) -> bool { true }
66+
fn visit_estr_slice(&self) -> bool { true }
67+
fn visit_estr_fixed(&self,
68+
_sz: uint, _sz: uint,
6669
_align: uint) -> bool { true }
6770

68-
fn visit_box(_mtbl: uint, _inner: *TyDesc) -> bool { true }
69-
fn visit_uniq(_mtbl: uint, _inner: *TyDesc) -> bool { true }
70-
fn visit_ptr(_mtbl: uint, _inner: *TyDesc) -> bool { true }
71-
fn visit_rptr(_mtbl: uint, _inner: *TyDesc) -> bool { true }
72-
73-
fn visit_vec(_mtbl: uint, inner: *TyDesc) -> bool {
74-
self.types += ~["["];
75-
visit_tydesc(inner, my_visitor(*self) as TyVisitor);
76-
self.types += ~["]"];
71+
fn visit_box(&self, _mtbl: uint, _inner: *TyDesc) -> bool { true }
72+
fn visit_uniq(&self, _mtbl: uint, _inner: *TyDesc) -> bool { true }
73+
fn visit_ptr(&self, _mtbl: uint, _inner: *TyDesc) -> bool { true }
74+
fn visit_rptr(&self, _mtbl: uint, _inner: *TyDesc) -> bool { true }
75+
76+
fn visit_vec(&self, _mtbl: uint, _inner: *TyDesc) -> bool { true }
77+
fn visit_unboxed_vec(&self, _mtbl: uint, _inner: *TyDesc) -> bool { true }
78+
fn visit_evec_box(&self, _mtbl: uint, _inner: *TyDesc) -> bool { true }
79+
fn visit_evec_uniq(&self, _mtbl: uint, inner: *TyDesc) -> bool {
80+
self.types.push(~"[");
81+
unsafe {
82+
visit_tydesc(inner, (@*self) as @TyVisitor);
83+
}
84+
self.types.push(~"]");
7785
true
7886
}
79-
fn visit_unboxed_vec(_mtbl: uint, _inner: *TyDesc) -> bool { true }
80-
fn visit_evec_box(_mtbl: uint, _inner: *TyDesc) -> bool { true }
81-
fn visit_evec_uniq(_mtbl: uint, _inner: *TyDesc) -> bool { true }
82-
fn visit_evec_slice(_mtbl: uint, _inner: *TyDesc) -> bool { true }
83-
fn visit_evec_fixed(_n: uint, _sz: uint, _align: uint,
87+
fn visit_evec_slice(&self, _mtbl: uint, _inner: *TyDesc) -> bool { true }
88+
fn visit_evec_fixed(&self, _n: uint, _sz: uint, _align: uint,
8489
_mtbl: uint, _inner: *TyDesc) -> bool { true }
8590

86-
fn visit_enter_rec(_n_fields: uint,
91+
fn visit_enter_rec(&self, _n_fields: uint,
8792
_sz: uint, _align: uint) -> bool { true }
88-
fn visit_rec_field(_i: uint, _name: &str,
93+
fn visit_rec_field(&self, _i: uint, _name: &str,
8994
_mtbl: uint, _inner: *TyDesc) -> bool { true }
90-
fn visit_leave_rec(_n_fields: uint,
95+
fn visit_leave_rec(&self, _n_fields: uint,
9196
_sz: uint, _align: uint) -> bool { true }
9297

93-
fn visit_enter_class(_n_fields: uint,
98+
fn visit_enter_class(&self, _n_fields: uint,
9499
_sz: uint, _align: uint) -> bool { true }
95-
fn visit_class_field(_i: uint, _name: &str,
100+
fn visit_class_field(&self, _i: uint, _name: &str,
96101
_mtbl: uint, _inner: *TyDesc) -> bool { true }
97-
fn visit_leave_class(_n_fields: uint,
102+
fn visit_leave_class(&self, _n_fields: uint,
98103
_sz: uint, _align: uint) -> bool { true }
99104

100-
fn visit_enter_tup(_n_fields: uint,
105+
fn visit_enter_tup(&self, _n_fields: uint,
101106
_sz: uint, _align: uint) -> bool { true }
102-
fn visit_tup_field(_i: uint, _inner: *TyDesc) -> bool { true }
103-
fn visit_leave_tup(_n_fields: uint,
107+
fn visit_tup_field(&self, _i: uint, _inner: *TyDesc) -> bool { true }
108+
fn visit_leave_tup(&self, _n_fields: uint,
104109
_sz: uint, _align: uint) -> bool { true }
105110

106-
fn visit_enter_enum(_n_variants: uint,
111+
fn visit_enter_enum(&self, _n_variants: uint,
112+
_get_disr: extern unsafe fn(ptr: *Opaque) -> int,
107113
_sz: uint, _align: uint) -> bool { true }
108-
fn visit_enter_enum_variant(_variant: uint,
114+
fn visit_enter_enum_variant(&self,
115+
_variant: uint,
109116
_disr_val: int,
110117
_n_fields: uint,
111118
_name: &str) -> bool { true }
112-
fn visit_enum_variant_field(_i: uint, _inner: *TyDesc) -> bool { true }
113-
fn visit_leave_enum_variant(_variant: uint,
119+
fn visit_enum_variant_field(&self, _i: uint, _offset: uint, _inner: *TyDesc) -> bool { true }
120+
fn visit_leave_enum_variant(&self,
121+
_variant: uint,
114122
_disr_val: int,
115123
_n_fields: uint,
116124
_name: &str) -> bool { true }
117-
fn visit_leave_enum(_n_variants: uint,
125+
fn visit_leave_enum(&self,
126+
_n_variants: uint,
127+
_get_disr: extern unsafe fn(ptr: *Opaque) -> int,
118128
_sz: uint, _align: uint) -> bool { true }
119129

120-
fn visit_enter_fn(_purity: uint, _proto: uint,
130+
fn visit_enter_fn(&self, _purity: uint, _proto: uint,
121131
_n_inputs: uint, _retstyle: uint) -> bool { true }
122-
fn visit_fn_input(_i: uint, _mode: uint, _inner: *TyDesc) -> bool { true }
123-
fn visit_fn_output(_retstyle: uint, _inner: *TyDesc) -> bool { true }
124-
fn visit_leave_fn(_purity: uint, _proto: uint,
132+
fn visit_fn_input(&self, _i: uint, _mode: uint, _inner: *TyDesc) -> bool { true }
133+
fn visit_fn_output(&self, _retstyle: uint, _inner: *TyDesc) -> bool { true }
134+
fn visit_leave_fn(&self, _purity: uint, _proto: uint,
125135
_n_inputs: uint, _retstyle: uint) -> bool { true }
126136

127137

128-
fn visit_trait() -> bool { true }
129-
fn visit_var() -> bool { true }
130-
fn visit_var_integral() -> bool { true }
131-
fn visit_param(_i: uint) -> bool { true }
132-
fn visit_self() -> bool { true }
133-
fn visit_type() -> bool { true }
134-
fn visit_opaque_box() -> bool { true }
135-
fn visit_constr(_inner: *TyDesc) -> bool { true }
136-
fn visit_closure_ptr(_ck: uint) -> bool { true }
138+
fn visit_trait(&self) -> bool { true }
139+
fn visit_var(&self) -> bool { true }
140+
fn visit_var_integral(&self) -> bool { true }
141+
fn visit_param(&self, _i: uint) -> bool { true }
142+
fn visit_self(&self) -> bool { true }
143+
fn visit_type(&self) -> bool { true }
144+
fn visit_opaque_box(&self) -> bool { true }
145+
fn visit_constr(&self, _inner: *TyDesc) -> bool { true }
146+
fn visit_closure_ptr(&self, _ck: uint) -> bool { true }
137147
}
138148

139-
fn visit_ty<T>(v: TyVisitor) {
140-
visit_tydesc(get_tydesc::<T>(), v);
149+
fn visit_ty<T>(v: @TyVisitor) {
150+
unsafe {
151+
visit_tydesc(get_tydesc::<T>(), v);
152+
}
141153
}
142154

143155
pub fn main() {
144-
let v = my_visitor(@mut {types: ~[]});
145-
let vv = v as TyVisitor;
156+
let v = @MyVisitor {types: @mut ~[]};
157+
let vv = v as @TyVisitor;
146158

147159
visit_ty::<bool>(vv);
148160
visit_ty::<int>(vv);
149161
visit_ty::<i8>(vv);
150162
visit_ty::<i16>(vv);
151163
visit_ty::<~[int]>(vv);
152164

153-
for (v.types.clone()).each {|s|
154-
io::println(fmt!("type: %s", s));
165+
for v.types.each |&s| {
166+
println(fmt!("type: %s", s));
155167
}
156-
assert!(v.types == ["bool", "int", "i8", "i16",
157-
"[", "int", "]"]);
168+
assert_eq!((*v.types).clone(), ~[~"bool", ~"int", ~"i8", ~"i16", ~"[", ~"int", ~"]"]);
158169
}

0 commit comments

Comments
 (0)