diff options
| author | Michael Woerister <michaelwoerister@posteo.net> | 2016-01-08 09:45:26 -0500 |
|---|---|---|
| committer | Michael Woerister <michaelwoerister@posteo.net> | 2016-01-08 09:45:26 -0500 |
| commit | c8a547a638a4e651b89dd8d4a68563b30e50c6d3 (patch) | |
| tree | 175fc7c975407ba3d378a43967e4e63b921f8ceb | |
| parent | 64a8ffeffaae2fe72994fb0832ae525346b8a3c0 (diff) | |
| download | rust-c8a547a638a4e651b89dd8d4a68563b30e50c6d3.tar.gz rust-c8a547a638a4e651b89dd8d4a68563b30e50c6d3.zip | |
Also store MIR of closures in crate metadata.
| -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(); } _ => { } |
