about summary refs log tree commit diff
diff options
context:
space:
mode:
authorJeffrey Seyfried <jeffrey.seyfried@gmail.com>2016-04-11 18:30:48 +0000
committerJeffrey Seyfried <jeffrey.seyfried@gmail.com>2016-04-11 18:30:48 +0000
commit3238b4bbbdd5b0a8c64ebeaedfa989d1babb3c21 (patch)
tree5e6dbf42a1b8ab2132337119083cd2270d95588b
parentfaea5ff6efae623c052e59120d18306cc6d9fd4a (diff)
downloadrust-3238b4bbbdd5b0a8c64ebeaedfa989d1babb3c21.tar.gz
rust-3238b4bbbdd5b0a8c64ebeaedfa989d1babb3c21.zip
Add comments
-rw-r--r--src/librustc_resolve/resolve_imports.rs4
1 files changed, 4 insertions, 0 deletions
diff --git a/src/librustc_resolve/resolve_imports.rs b/src/librustc_resolve/resolve_imports.rs
index 2f2c5b77dd0..1404b8cf3ad 100644
--- a/src/librustc_resolve/resolve_imports.rs
+++ b/src/librustc_resolve/resolve_imports.rs
@@ -317,6 +317,8 @@ impl<'a> ::ModuleS<'a> {
     fn update_resolution<T, F>(&self, name: Name, ns: Namespace, update: F) -> T
         where F: FnOnce(&mut NameResolution<'a>) -> T
     {
+        // Ensure that `resolution` isn't borrowed during `define_in_glob_importers`,
+        // where it might end up getting re-defined via a glob cycle.
         let (new_binding, t) = {
             let mut resolution = &mut *self.resolution(name, ns).borrow_mut();
             let was_known = resolution.binding().is_some();
@@ -650,6 +652,8 @@ impl<'a, 'b:'a, 'tcx:'b> ImportResolver<'a, 'b, 'tcx> {
         // Add to target_module's glob_importers
         target_module.glob_importers.borrow_mut().push((module_, directive));
 
+        // Ensure that `resolutions` isn't borrowed during `try_define_child`,
+        // since it might get updated via a glob cycle.
         let bindings = target_module.resolutions.borrow().iter().filter_map(|(name, resolution)| {
             resolution.borrow().binding().map(|binding| (*name, binding))
         }).collect::<Vec<_>>();