diff options
| author | bors <bors@rust-lang.org> | 2018-04-10 12:58:27 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2018-04-10 12:58:27 +0000 |
| commit | b2a7b94b8edf4e6858ee5878c3b9e6b410d00703 (patch) | |
| tree | a9eed62338da894662e9af85527fbb2eca43507a | |
| parent | 67712d79451b042b6fca2167c1a57d91d86f663b (diff) | |
| parent | ebbe0c210c60fce57db4e0f5f2a805c9bfe41ac6 (diff) | |
| download | rust-b2a7b94b8edf4e6858ee5878c3b9e6b410d00703.tar.gz rust-b2a7b94b8edf4e6858ee5878c3b9e6b410d00703.zip | |
Auto merge of #49386 - GuillaumeGomez:fix-path-attribute, r=eddyb
Add tcx in item_body_nested_bodies Fixes #47391. r? @eddyb
| -rw-r--r-- | src/librustc_metadata/cstore_impl.rs | 2 | ||||
| -rw-r--r-- | src/librustc_metadata/decoder.rs | 9 |
2 files changed, 7 insertions, 4 deletions
diff --git a/src/librustc_metadata/cstore_impl.rs b/src/librustc_metadata/cstore_impl.rs index 51088563c7b..2c995d2f5cd 100644 --- a/src/librustc_metadata/cstore_impl.rs +++ b/src/librustc_metadata/cstore_impl.rs @@ -163,7 +163,7 @@ provide! { <'tcx> tcx, def_id, other, cdata, fn_arg_names => { cdata.get_fn_arg_names(def_id.index) } impl_parent => { cdata.get_parent_impl(def_id.index) } trait_of_item => { cdata.get_trait_of_item(def_id.index) } - item_body_nested_bodies => { cdata.item_body_nested_bodies(def_id.index) } + item_body_nested_bodies => { cdata.item_body_nested_bodies(tcx, def_id.index) } const_is_rvalue_promotable_to_static => { cdata.const_is_rvalue_promotable_to_static(def_id.index) } diff --git a/src/librustc_metadata/decoder.rs b/src/librustc_metadata/decoder.rs index 42e208ded49..3ea4ddc2522 100644 --- a/src/librustc_metadata/decoder.rs +++ b/src/librustc_metadata/decoder.rs @@ -818,11 +818,14 @@ impl<'a, 'tcx> CrateMetadata { tcx.alloc_tables(ast.tables.decode((self, tcx))) } - pub fn item_body_nested_bodies(&self, id: DefIndex) -> ExternBodyNestedBodies { + pub fn item_body_nested_bodies(&self, + tcx: TyCtxt<'a, 'tcx, 'tcx>, + id: DefIndex) + -> ExternBodyNestedBodies { if let Some(ref ast) = self.entry(id).ast { - let ast = ast.decode(self); + let mut ast = ast.decode(self); let nested_bodies: BTreeMap<_, _> = ast.nested_bodies - .decode(self) + .decode((self, tcx.sess)) .map(|body| (body.id(), body)) .collect(); ExternBodyNestedBodies { |
