Skip to content

Commit efe9d74

Browse files
committed
syntax: add a visit_ident method to the Visitor.
1 parent 1dea21f commit efe9d74

File tree

1 file changed

+45
-3
lines changed

1 file changed

+45
-3
lines changed

src/libsyntax/visit.rs

+45-3
Original file line numberDiff line numberDiff line change
@@ -67,6 +67,9 @@ pub fn generics_of_fn(fk: &fn_kind) -> Generics {
6767
}
6868

6969
pub trait Visitor<E:Clone> {
70+
fn visit_ident(&mut self, _sp: Span, _ident: Ident, _e: E) {
71+
/*! Visit the idents */
72+
}
7073
fn visit_mod(&mut self, m:&_mod, _s:Span, _n:NodeId, e:E) { walk_mod(self, m, e) }
7174
fn visit_view_item(&mut self, i:&view_item, e:E) { walk_view_item(self, i, e) }
7275
fn visit_foreign_item(&mut self, i:@foreign_item, e:E) { walk_foreign_item(self, i, e) }
@@ -132,8 +135,31 @@ pub fn walk_mod<E:Clone, V:Visitor<E>>(visitor: &mut V, module: &_mod, env: E) {
132135
}
133136
}
134137

135-
pub fn walk_view_item<E:Clone, V:Visitor<E>>(_: &mut V, _: &view_item, _: E) {
136-
// Empty!
138+
pub fn walk_view_item<E:Clone, V:Visitor<E>>(visitor: &mut V, vi: &view_item, env: E) {
139+
match vi.node {
140+
view_item_extern_mod(name, _, _, _) => {
141+
visitor.visit_ident(vi.span, name, env)
142+
}
143+
view_item_use(ref paths) => {
144+
for vp in paths.iter() {
145+
let path = match vp.node {
146+
view_path_simple(ident, ref path, _) => {
147+
visitor.visit_ident(vp.span, ident, env.clone());
148+
path
149+
}
150+
view_path_glob(ref path, _) => path,
151+
view_path_list(ref path, ref list, _) => {
152+
for id in list.iter() {
153+
visitor.visit_ident(id.span, id.node.name, env.clone())
154+
}
155+
path
156+
}
157+
};
158+
159+
walk_path(visitor, path, env.clone());
160+
}
161+
}
162+
}
137163
}
138164

139165
pub fn walk_local<E:Clone, V:Visitor<E>>(visitor: &mut V, local: &Local, env: E) {
@@ -164,6 +190,7 @@ fn walk_trait_ref<E:Clone, V:Visitor<E>>(visitor: &mut V,
164190
}
165191

166192
pub fn walk_item<E:Clone, V:Visitor<E>>(visitor: &mut V, item: &item, env: E) {
193+
visitor.visit_ident(item.span, item.ident, env.clone());
167194
match item.node {
168195
item_static(ref typ, _, expr) => {
169196
visitor.visit_ty(typ, env.clone());
@@ -243,6 +270,8 @@ pub fn walk_variant<E:Clone, V:Visitor<E>>(visitor:&mut V,
243270
variant: &variant,
244271
generics: &Generics,
245272
env: E) {
273+
visitor.visit_ident(variant.span, variant.node.name, env.clone());
274+
246275
match variant.node.kind {
247276
tuple_variant_kind(ref variant_arguments) => {
248277
for variant_argument in variant_arguments.iter() {
@@ -328,6 +357,8 @@ fn walk_lifetime_decls<E:Clone, V:Visitor<E>>(visitor: &mut V,
328357

329358
pub fn walk_path<E:Clone, V:Visitor<E>>(visitor: &mut V, path: &Path, env: E) {
330359
for segment in path.segments.iter() {
360+
visitor.visit_ident(path.span, segment.identifier, env.clone());
361+
331362
for typ in segment.types.iter() {
332363
visitor.visit_ty(typ, env.clone());
333364
}
@@ -393,6 +424,8 @@ pub fn walk_pat<E:Clone, V:Visitor<E>>(visitor: &mut V, pattern: &Pat, env: E) {
393424
pub fn walk_foreign_item<E:Clone, V:Visitor<E>>(visitor: &mut V,
394425
foreign_item: &foreign_item,
395426
env: E) {
427+
visitor.visit_ident(foreign_item.span, foreign_item.ident, env.clone());
428+
396429
match foreign_item.node {
397430
foreign_item_fn(ref function_declaration, ref generics) => {
398431
walk_fn_decl(visitor, function_declaration, env.clone());
@@ -441,6 +474,7 @@ pub fn walk_fn_decl<E:Clone, V:Visitor<E>>(visitor: &mut V,
441474
pub fn walk_method_helper<E:Clone, V:Visitor<E>>(visitor: &mut V,
442475
method: &method,
443476
env: E) {
477+
visitor.visit_ident(method.span, method.ident, env.clone());
444478
visitor.visit_fn(&fk_method(method.ident, &method.generics, method),
445479
&method.decl,
446480
&method.body,
@@ -477,12 +511,13 @@ pub fn walk_fn<E:Clone, V:Visitor<E>>(visitor: &mut V,
477511
pub fn walk_ty_method<E:Clone, V:Visitor<E>>(visitor: &mut V,
478512
method_type: &TypeMethod,
479513
env: E) {
514+
visitor.visit_ident(method_type.span, method_type.ident, env.clone());
480515
visitor.visit_explicit_self(&method_type.explicit_self, env.clone());
481516
for argument_type in method_type.decl.inputs.iter() {
482517
visitor.visit_ty(&argument_type.ty, env.clone())
483518
}
484519
visitor.visit_generics(&method_type.generics, env.clone());
485-
visitor.visit_ty(&method_type.decl.output, env.clone())
520+
visitor.visit_ty(&method_type.decl.output, env);
486521
}
487522

488523
pub fn walk_trait_method<E:Clone, V:Visitor<E>>(visitor: &mut V,
@@ -510,6 +545,13 @@ pub fn walk_struct_def<E:Clone, V:Visitor<E>>(visitor: &mut V,
510545
pub fn walk_struct_field<E:Clone, V:Visitor<E>>(visitor: &mut V,
511546
struct_field: &struct_field,
512547
env: E) {
548+
match struct_field.node.kind {
549+
named_field(name, _) => {
550+
visitor.visit_ident(struct_field.span, name, env.clone())
551+
}
552+
_ => {}
553+
}
554+
513555
visitor.visit_ty(&struct_field.node.ty, env)
514556
}
515557

0 commit comments

Comments
 (0)