let attrs = self.context.tcx.hir().attrs(id);
let prev = self.context.last_node_with_lint_attrs;
self.context.last_node_with_lint_attrs = id;
- self.enter_attrs(attrs);
+ debug!("late context: enter_attrs({:?})", attrs);
+ lint_callback!(self, enter_lint_attrs, attrs);
f(self);
- self.exit_attrs(attrs);
+ debug!("late context: exit_attrs({:?})", attrs);
+ lint_callback!(self, exit_lint_attrs, attrs);
self.context.last_node_with_lint_attrs = prev;
}
hir_visit::walk_mod(self, m, n);
lint_callback!(self, check_mod_post, m, s, n);
}
-
- fn enter_attrs(&mut self, attrs: &'tcx [ast::Attribute]) {
- debug!("late context: enter_attrs({:?})", attrs);
- lint_callback!(self, enter_lint_attrs, attrs);
- }
-
- fn exit_attrs(&mut self, attrs: &'tcx [ast::Attribute]) {
- debug!("late context: exit_attrs({:?})", attrs);
- lint_callback!(self, exit_lint_attrs, attrs);
- }
}
impl<'tcx, T: LateLintPass<'tcx>> hir_visit::Visitor<'tcx> for LateContextAndPass<'tcx, T> {
hir_visit::walk_path(self, p);
}
- fn visit_attribute(&mut self, hir_id: hir::HirId, attr: &'tcx ast::Attribute) {
- self.with_lint_attrs(hir_id, |cx| {
- lint_callback!(cx, check_attribute, attr);
- })
+ fn visit_attribute(&mut self, attr: &'tcx ast::Attribute) {
+ lint_callback!(self, check_attribute, attr);
}
}
// Visit the crate attributes
if hir_id == hir::CRATE_HIR_ID {
for attr in tcx.hir().attrs(hir::CRATE_HIR_ID).iter() {
- cx.visit_attribute(hir_id, attr)
+ cx.visit_attribute(attr)
}
}
}