Skip to content

Commit 6fac703

Browse files
ICH: Fix some omissions around foreign mods in hasher.
1 parent d0c61eb commit 6fac703

File tree

2 files changed

+35
-9
lines changed

2 files changed

+35
-9
lines changed

src/librustc/hir/intravisit.rs

+8-5
Original file line numberDiff line numberDiff line change
@@ -264,6 +264,9 @@ pub trait Visitor<'v> : Sized {
264264
fn visit_where_predicate(&mut self, predicate: &'v WherePredicate) {
265265
walk_where_predicate(self, predicate)
266266
}
267+
fn visit_fn_decl(&mut self, fd: &'v FnDecl) {
268+
walk_fn_decl(self, fd)
269+
}
267270
fn visit_fn(&mut self, fk: FnKind<'v>, fd: &'v FnDecl, b: ExprId, s: Span, id: NodeId) {
268271
walk_fn(self, fk, fd, b, s, id)
269272
}
@@ -532,7 +535,7 @@ pub fn walk_ty<'v, V: Visitor<'v>>(visitor: &mut V, typ: &'v Ty) {
532535
walk_list!(visitor, visit_ty, tuple_element_types);
533536
}
534537
TyBareFn(ref function_declaration) => {
535-
walk_fn_decl(visitor, &function_declaration.decl);
538+
visitor.visit_fn_decl(&function_declaration.decl);
536539
walk_list!(visitor, visit_lifetime_def, &function_declaration.lifetimes);
537540
}
538541
TyPath(ref qpath) => {
@@ -661,7 +664,7 @@ pub fn walk_foreign_item<'v, V: Visitor<'v>>(visitor: &mut V, foreign_item: &'v
661664

662665
match foreign_item.node {
663666
ForeignItemFn(ref function_declaration, ref generics) => {
664-
walk_fn_decl(visitor, function_declaration);
667+
visitor.visit_fn_decl(function_declaration);
665668
visitor.visit_generics(generics)
666669
}
667670
ForeignItemStatic(ref typ, _) => visitor.visit_ty(typ),
@@ -765,7 +768,7 @@ pub fn walk_fn<'v, V: Visitor<'v>>(visitor: &mut V,
765768
_span: Span,
766769
id: NodeId) {
767770
visitor.visit_id(id);
768-
walk_fn_decl(visitor, function_declaration);
771+
visitor.visit_fn_decl(function_declaration);
769772
walk_fn_kind(visitor, function_kind);
770773
visitor.visit_body(body_id)
771774
}
@@ -777,7 +780,7 @@ pub fn walk_fn_with_body<'v, V: Visitor<'v>>(visitor: &mut V,
777780
_span: Span,
778781
id: NodeId) {
779782
visitor.visit_id(id);
780-
walk_fn_decl(visitor, function_declaration);
783+
visitor.visit_fn_decl(function_declaration);
781784
walk_fn_kind(visitor, function_kind);
782785
visitor.visit_expr(body)
783786
}
@@ -794,7 +797,7 @@ pub fn walk_trait_item<'v, V: Visitor<'v>>(visitor: &mut V, trait_item: &'v Trai
794797
MethodTraitItem(ref sig, None) => {
795798
visitor.visit_id(trait_item.id);
796799
visitor.visit_generics(&sig.generics);
797-
walk_fn_decl(visitor, &sig.decl);
800+
visitor.visit_fn_decl(&sig.decl);
798801
}
799802
MethodTraitItem(ref sig, Some(body_id)) => {
800803
visitor.visit_fn(FnKind::Method(trait_item.name,

src/librustc_incremental/calculate_svh/svh_visitor.rs

+27-4
Original file line numberDiff line numberDiff line change
@@ -180,9 +180,10 @@ enum SawAbiComponent<'a> {
180180
SawLifetimeDef(usize),
181181

182182
SawMod,
183-
SawForeignItem,
183+
SawForeignItem(SawForeignItemComponent),
184184
SawItem(SawItemComponent),
185185
SawTy(SawTyComponent),
186+
SawFnDecl(bool),
186187
SawGenerics,
187188
SawTraitItem(SawTraitOrImplItemComponent),
188189
SawImplItem(SawTraitOrImplItemComponent),
@@ -364,7 +365,7 @@ enum SawItemComponent {
364365
SawItemConst,
365366
SawItemFn(Unsafety, Constness, Abi),
366367
SawItemMod,
367-
SawItemForeignMod,
368+
SawItemForeignMod(Abi),
368369
SawItemTy,
369370
SawItemEnum,
370371
SawItemStruct,
@@ -382,7 +383,7 @@ fn saw_item(node: &Item_) -> SawItemComponent {
382383
ItemConst(..) =>SawItemConst,
383384
ItemFn(_, unsafety, constness, abi, _, _) => SawItemFn(unsafety, constness, abi),
384385
ItemMod(..) => SawItemMod,
385-
ItemForeignMod(..) => SawItemForeignMod,
386+
ItemForeignMod(ref fm) => SawItemForeignMod(fm.abi),
386387
ItemTy(..) => SawItemTy,
387388
ItemEnum(..) => SawItemEnum,
388389
ItemStruct(..) => SawItemStruct,
@@ -393,6 +394,12 @@ fn saw_item(node: &Item_) -> SawItemComponent {
393394
}
394395
}
395396

397+
#[derive(Hash)]
398+
enum SawForeignItemComponent {
399+
Static { mutable: bool },
400+
Fn,
401+
}
402+
396403
#[derive(Hash)]
397404
enum SawPatComponent {
398405
SawPatWild,
@@ -602,7 +609,17 @@ impl<'a, 'hash, 'tcx> visit::Visitor<'tcx> for StrictVersionHashVisitor<'a, 'has
602609
fn visit_foreign_item(&mut self, i: &'tcx ForeignItem) {
603610
debug!("visit_foreign_item: st={:?}", self.st);
604611

605-
SawForeignItem.hash(self.st);
612+
match i.node {
613+
ForeignItemFn(..) => {
614+
SawForeignItem(SawForeignItemComponent::Fn)
615+
}
616+
ForeignItemStatic(_, mutable) => {
617+
SawForeignItem(SawForeignItemComponent::Static {
618+
mutable: mutable
619+
})
620+
}
621+
}.hash(self.st);
622+
606623
hash_span!(self, i.span);
607624
hash_attrs!(self, &i.attrs);
608625
visit::walk_foreign_item(self, i)
@@ -639,6 +656,12 @@ impl<'a, 'hash, 'tcx> visit::Visitor<'tcx> for StrictVersionHashVisitor<'a, 'has
639656
visit::walk_generics(self, g)
640657
}
641658

659+
fn visit_fn_decl(&mut self, fd: &'tcx FnDecl) {
660+
debug!("visit_fn_decl: st={:?}", self.st);
661+
SawFnDecl(fd.variadic).hash(self.st);
662+
visit::walk_fn_decl(self, fd)
663+
}
664+
642665
fn visit_trait_item(&mut self, ti: &'tcx TraitItem) {
643666
debug!("visit_trait_item: st={:?}", self.st);
644667

0 commit comments

Comments
 (0)