Skip to content

Commit 7d641c6

Browse files
jseyfriedalexcrichton
authored andcommitted
---
yaml --- r: 278263 b: refs/heads/beta c: 8bede43 h: refs/heads/master i: 278261: f0b0578 278259: 0563577 278255: 8bc02cc
1 parent 289fce2 commit 7d641c6

File tree

2 files changed

+5
-1
lines changed

2 files changed

+5
-1
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,7 @@ refs/tags/0.9: 36870b185fc5f5486636d4515f0e22677493f225
2323
refs/tags/0.10: ac33f2b15782272ae348dbd7b14b8257b2148b5a
2424
refs/tags/0.11.0: e1247cb1d0d681be034adb4b558b5a0c0d5720f9
2525
refs/tags/0.12.0: f0c419429ef30723ceaf6b42f9b5a2aeb5d2e2d1
26-
refs/heads/beta: 6f61c942b63c5861e574ca92fe1d9beeec60c4ab
26+
refs/heads/beta: 8bede4302a086afd78af89e9b64d5d0757f637e3
2727
refs/tags/1.0.0-alpha: e42bd6d93a1d3433c486200587f8f9e12590a4d7
2828
refs/heads/tmp: e06d2ad9fcd5027bcaac5b08fc9aa39a49d0ecd3
2929
refs/tags/1.0.0-alpha.2: 4c705f6bc559886632d3871b04f58aab093bfa2f

branches/beta/src/librustc_resolve/resolve_imports.rs

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -317,6 +317,8 @@ impl<'a> ::ModuleS<'a> {
317317
fn update_resolution<T, F>(&self, name: Name, ns: Namespace, update: F) -> T
318318
where F: FnOnce(&mut NameResolution<'a>) -> T
319319
{
320+
// Ensure that `resolution` isn't borrowed during `define_in_glob_importers`,
321+
// where it might end up getting re-defined via a glob cycle.
320322
let (new_binding, t) = {
321323
let mut resolution = &mut *self.resolution(name, ns).borrow_mut();
322324
let was_known = resolution.binding().is_some();
@@ -650,6 +652,8 @@ impl<'a, 'b:'a, 'tcx:'b> ImportResolver<'a, 'b, 'tcx> {
650652
// Add to target_module's glob_importers
651653
target_module.glob_importers.borrow_mut().push((module_, directive));
652654

655+
// Ensure that `resolutions` isn't borrowed during `try_define_child`,
656+
// since it might get updated via a glob cycle.
653657
let bindings = target_module.resolutions.borrow().iter().filter_map(|(name, resolution)| {
654658
resolution.borrow().binding().map(|binding| (*name, binding))
655659
}).collect::<Vec<_>>();

0 commit comments

Comments
 (0)