|
8 | 8 | // option. This file may not be copied, modified, or distributed
|
9 | 9 | // except according to those terms.
|
10 | 10 |
|
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}; |
14 | 12 |
|
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"); |
18 | 20 | error!("visited bot type");
|
19 | 21 | true
|
20 | 22 | }
|
21 |
| - fn visit_nil() -> bool { |
22 |
| - self.types += ~["nil"]; |
| 23 | + fn visit_nil(&self) -> bool { |
| 24 | + self.types.push(~"nil"); |
23 | 25 | error!("visited nil type");
|
24 | 26 | true
|
25 | 27 | }
|
26 |
| - fn visit_bool() -> bool { |
27 |
| - self.types += ~["bool"]; |
| 28 | + fn visit_bool(&self) -> bool { |
| 29 | + self.types.push(~"bool"); |
28 | 30 | error!("visited bool type");
|
29 | 31 | true
|
30 | 32 | }
|
31 |
| - fn visit_int() -> bool { |
32 |
| - self.types += ~["int"]; |
| 33 | + fn visit_int(&self) -> bool { |
| 34 | + self.types.push(~"int"); |
33 | 35 | error!("visited int type");
|
34 | 36 | true
|
35 | 37 | }
|
36 |
| - fn visit_i8() -> bool { |
37 |
| - self.types += ~["i8"]; |
| 38 | + fn visit_i8(&self) -> bool { |
| 39 | + self.types.push(~"i8"); |
38 | 40 | error!("visited i8 type");
|
39 | 41 | true
|
40 | 42 | }
|
41 |
| - fn visit_i16() -> bool { |
42 |
| - self.types += ~["i16"]; |
| 43 | + fn visit_i16(&self) -> bool { |
| 44 | + self.types.push(~"i16"); |
43 | 45 | error!("visited i16 type");
|
44 | 46 | true
|
45 | 47 | }
|
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, |
66 | 69 | _align: uint) -> bool { true }
|
67 | 70 |
|
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(~"]"); |
77 | 85 | true
|
78 | 86 | }
|
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, |
84 | 89 | _mtbl: uint, _inner: *TyDesc) -> bool { true }
|
85 | 90 |
|
86 |
| - fn visit_enter_rec(_n_fields: uint, |
| 91 | + fn visit_enter_rec(&self, _n_fields: uint, |
87 | 92 | _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, |
89 | 94 | _mtbl: uint, _inner: *TyDesc) -> bool { true }
|
90 |
| - fn visit_leave_rec(_n_fields: uint, |
| 95 | + fn visit_leave_rec(&self, _n_fields: uint, |
91 | 96 | _sz: uint, _align: uint) -> bool { true }
|
92 | 97 |
|
93 |
| - fn visit_enter_class(_n_fields: uint, |
| 98 | + fn visit_enter_class(&self, _n_fields: uint, |
94 | 99 | _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, |
96 | 101 | _mtbl: uint, _inner: *TyDesc) -> bool { true }
|
97 |
| - fn visit_leave_class(_n_fields: uint, |
| 102 | + fn visit_leave_class(&self, _n_fields: uint, |
98 | 103 | _sz: uint, _align: uint) -> bool { true }
|
99 | 104 |
|
100 |
| - fn visit_enter_tup(_n_fields: uint, |
| 105 | + fn visit_enter_tup(&self, _n_fields: uint, |
101 | 106 | _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, |
104 | 109 | _sz: uint, _align: uint) -> bool { true }
|
105 | 110 |
|
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, |
107 | 113 | _sz: uint, _align: uint) -> bool { true }
|
108 |
| - fn visit_enter_enum_variant(_variant: uint, |
| 114 | + fn visit_enter_enum_variant(&self, |
| 115 | + _variant: uint, |
109 | 116 | _disr_val: int,
|
110 | 117 | _n_fields: uint,
|
111 | 118 | _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, |
114 | 122 | _disr_val: int,
|
115 | 123 | _n_fields: uint,
|
116 | 124 | _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, |
118 | 128 | _sz: uint, _align: uint) -> bool { true }
|
119 | 129 |
|
120 |
| - fn visit_enter_fn(_purity: uint, _proto: uint, |
| 130 | + fn visit_enter_fn(&self, _purity: uint, _proto: uint, |
121 | 131 | _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, |
125 | 135 | _n_inputs: uint, _retstyle: uint) -> bool { true }
|
126 | 136 |
|
127 | 137 |
|
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 } |
137 | 147 | }
|
138 | 148 |
|
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 | + } |
141 | 153 | }
|
142 | 154 |
|
143 | 155 | 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; |
146 | 158 |
|
147 | 159 | visit_ty::<bool>(vv);
|
148 | 160 | visit_ty::<int>(vv);
|
149 | 161 | visit_ty::<i8>(vv);
|
150 | 162 | visit_ty::<i16>(vv);
|
151 | 163 | visit_ty::<~[int]>(vv);
|
152 | 164 |
|
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)); |
155 | 167 | }
|
156 |
| - assert!(v.types == ["bool", "int", "i8", "i16", |
157 |
| - "[", "int", "]"]); |
| 168 | + assert_eq!((*v.types).clone(), ~[~"bool", ~"int", ~"i8", ~"i16", ~"[", ~"int", ~"]"]); |
158 | 169 | }
|
0 commit comments