diff options
| author | bors <bors@rust-lang.org> | 2016-01-13 15:08:07 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2016-01-13 15:08:07 +0000 |
| commit | 7aed245d69649c3f8bb0865e0d270cfad78e4537 (patch) | |
| tree | 845968fa147397168198b4c29e9e51b9b1fb52d3 | |
| parent | d3c83fef245f1cb2e523c8913b8968c98faec1f4 (diff) | |
| parent | c8a547a638a4e651b89dd8d4a68563b30e50c6d3 (diff) | |
| download | rust-7aed245d69649c3f8bb0865e0d270cfad78e4537.tar.gz rust-7aed245d69649c3f8bb0865e0d270cfad78e4537.zip | |
Auto merge of #30779 - michaelwoerister:closure-mir-in-metadata, r=nikomatsakis
| -rw-r--r-- | src/librustc_metadata/encoder.rs | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/src/librustc_metadata/encoder.rs b/src/librustc_metadata/encoder.rs index 26f32e20764..22da853dfed 100644 --- a/src/librustc_metadata/encoder.rs +++ b/src/librustc_metadata/encoder.rs @@ -806,18 +806,18 @@ fn encode_inlined_item(ecx: &EncodeContext, let eii: &mut EncodeInlinedItem = &mut *eii; eii(ecx, rbml_w, ii); - encode_mir(ecx, rbml_w, ii); -} - -fn encode_mir(ecx: &EncodeContext, rbml_w: &mut Encoder, ii: InlinedItemRef) { - let id = match ii { + let node_id = match ii { InlinedItemRef::Item(item) => item.id, InlinedItemRef::TraitItem(_, trait_item) => trait_item.id, InlinedItemRef::ImplItem(_, impl_item) => impl_item.id, InlinedItemRef::Foreign(foreign_item) => foreign_item.id }; - if let Some(mir) = ecx.mir_map.get(&id) { + encode_mir(ecx, rbml_w, node_id); +} + +fn encode_mir(ecx: &EncodeContext, rbml_w: &mut Encoder, node_id: NodeId) { + if let Some(mir) = ecx.mir_map.get(&node_id) { rbml_w.start_tag(tag_mir as usize); rbml_w.emit_opaque(|opaque_encoder| { tls::enter_encoding_context(ecx, opaque_encoder, |_, opaque_encoder| { @@ -1436,6 +1436,9 @@ fn my_visit_expr(expr: &hir::Expr, ecx.tcx.map.with_path(expr.id, |path| encode_path(rbml_w, path)); + assert!(ecx.mir_map.contains_key(&expr.id)); + encode_mir(ecx, rbml_w, expr.id); + rbml_w.end_tag(); } _ => { } |
