]> git.lizzy.rs Git - rust.git/commitdiff
Refactor `record_used: bool` -> `record_used: Option<Span>`.
authorJeffrey Seyfried <jeffrey.seyfried@gmail.com>
Fri, 5 Aug 2016 01:58:59 +0000 (01:58 +0000)
committerJeffrey Seyfried <jeffrey.seyfried@gmail.com>
Thu, 18 Aug 2016 03:22:47 +0000 (03:22 +0000)
src/librustc_resolve/lib.rs
src/librustc_resolve/resolve_imports.rs

index efc0247e6ff09aa4b004468a20c1bde6e0fc95e2..f200ae2f75873eec402ac1872f6b55d1edf82a38 100644 (file)
@@ -1246,7 +1246,7 @@ fn resolve_module_path_from_root(&mut self,
                                      -> ResolveResult<Module<'a>> {
         fn search_parent_externals<'a>(this: &mut Resolver<'a>, needle: Name, module: Module<'a>)
                                        -> Option<Module<'a>> {
-            match this.resolve_name_in_module(module, needle, TypeNS, false, false) {
+            match this.resolve_name_in_module(module, needle, TypeNS, false, None) {
                 Success(binding) if binding.is_extern_crate() => Some(module),
                 _ => match module.parent_link {
                     ModuleParentLink(ref parent, _) => {
@@ -1265,7 +1265,7 @@ fn search_parent_externals<'a>(this: &mut Resolver<'a>, needle: Name, module: Mo
         // modules as we go.
         while index < module_path_len {
             let name = module_path[index];
-            match self.resolve_name_in_module(search_module, name, TypeNS, false, true) {
+            match self.resolve_name_in_module(search_module, name, TypeNS, false, Some(span)) {
                 Failed(None) => {
                     let segment_name = name.as_str();
                     let module_name = module_to_string(search_module);
@@ -1361,7 +1361,7 @@ fn resolve_module_path(&mut self,
                         // first component of the path in the current lexical
                         // scope and then proceed to resolve below that.
                         let ident = ast::Ident::with_empty_ctxt(module_path[0]);
-                        match self.resolve_ident_in_lexical_scope(ident, TypeNS, true)
+                        match self.resolve_ident_in_lexical_scope(ident, TypeNS, Some(span))
                                   .and_then(LexicalScopeBinding::module) {
                             None => return Failed(None),
                             Some(containing_module) => {
@@ -1404,7 +1404,7 @@ fn resolve_module_path(&mut self,
     fn resolve_ident_in_lexical_scope(&mut self,
                                       mut ident: ast::Ident,
                                       ns: Namespace,
-                                      record_used: bool)
+                                      record_used: Option<Span>)
                                       -> Option<LexicalScopeBinding<'a>> {
         if ns == TypeNS {
             ident = ast::Ident::with_empty_ctxt(ident.name);
@@ -1432,7 +1432,7 @@ fn resolve_ident_in_lexical_scope(&mut self,
                 if module.def.is_some() {
                     return match self.prelude {
                         Some(prelude) if !module.no_implicit_prelude.get() => {
-                            self.resolve_name_in_module(prelude, name, ns, false, false).success()
+                            self.resolve_name_in_module(prelude, name, ns, false, None).success()
                                 .map(LexicalScopeBinding::Item)
                         }
                         _ => None,
@@ -2287,7 +2287,7 @@ fn resolve_pattern(&mut self,
                 PatKind::Ident(bmode, ref ident, ref opt_pat) => {
                     // First try to resolve the identifier as some existing
                     // entity, then fall back to a fresh binding.
-                    let binding = self.resolve_ident_in_lexical_scope(ident.node, ValueNS, false)
+                    let binding = self.resolve_ident_in_lexical_scope(ident.node, ValueNS, None)
                                       .and_then(LexicalScopeBinding::item);
                     let resolution = binding.and_then(NameBinding::def).and_then(|def| {
                         let always_binding = !pat_src.is_refutable() || opt_pat.is_some() ||
@@ -2454,11 +2454,11 @@ fn resolve_path(&mut self, id: NodeId, path: &Path, path_depth: usize, namespace
             //
             // Such behavior is required for backward compatibility.
             // The same fallback is used when `a` resolves to nothing.
-            let def = resolve_identifier_with_fallback(self, true).ok_or(false);
+            let def = resolve_identifier_with_fallback(self, Some(span)).ok_or(false);
             return def.and_then(|def| self.adjust_local_def(def, span).ok_or(true)).map(mk_res);
         }
 
-        let unqualified_def = resolve_identifier_with_fallback(self, false);
+        let unqualified_def = resolve_identifier_with_fallback(self, None);
         let qualified_binding = self.resolve_module_relative_path(span, segments, namespace);
         match (qualified_binding, unqualified_def) {
             (Ok(binding), Some(ref ud)) if binding.def().unwrap() == ud.def => {
@@ -2478,7 +2478,7 @@ fn resolve_path(&mut self, id: NodeId, path: &Path, path_depth: usize, namespace
     fn resolve_identifier(&mut self,
                           identifier: ast::Ident,
                           namespace: Namespace,
-                          record_used: bool)
+                          record_used: Option<Span>)
                           -> Option<LocalDef> {
         if identifier.name == keywords::Invalid.name() {
             return None;
@@ -2613,7 +2613,8 @@ fn resolve_module_relative_path(&mut self,
         }
 
         let name = segments.last().unwrap().identifier.name;
-        let result = self.resolve_name_in_module(containing_module, name, namespace, false, true);
+        let result =
+            self.resolve_name_in_module(containing_module, name, namespace, false, Some(span));
         result.success().map(|binding| {
             self.check_privacy(name, binding, span);
             binding
@@ -2657,7 +2658,8 @@ fn resolve_crate_relative_path<T>(&mut self, span: Span, segments: &[T], namespa
         }
 
         let name = segments.last().unwrap().name();
-        let result = self.resolve_name_in_module(containing_module, name, namespace, false, true);
+        let result =
+            self.resolve_name_in_module(containing_module, name, namespace, false, Some(span));
         result.success().map(|binding| {
             self.check_privacy(name, binding, span);
             binding
index 05c4430a687007d659914803c7405f099733d3cd..28401b2e240f0f1e20837431d8e4ba67e53e7cec 100644 (file)
@@ -149,7 +149,7 @@ pub fn resolve_name_in_module(&mut self,
                                   name: Name,
                                   ns: Namespace,
                                   allow_private_imports: bool,
-                                  record_used: bool)
+                                  record_used: Option<Span>)
                                   -> ResolveResult<&'a NameBinding<'a>> {
         self.populate_module_if_necessary(module);
 
@@ -165,7 +165,7 @@ pub fn resolve_name_in_module(&mut self,
                 if !allow_private_imports && binding.is_import() && !binding.is_pseudo_public() {
                     return Failed(None);
                 }
-                if record_used {
+                if record_used.is_some() {
                     self.record_use(name, ns, binding);
                 }
                 Success(binding)
@@ -176,7 +176,7 @@ pub fn resolve_name_in_module(&mut self,
         for directive in module.globs.borrow().iter() {
             if !allow_private_imports && directive.vis != ty::Visibility::Public { continue }
             if let Some(target_module) = directive.target_module.get() {
-                let result = self.resolve_name_in_module(target_module, name, ns, false, false);
+                let result = self.resolve_name_in_module(target_module, name, ns, false, None);
                 if let Indeterminate = result {
                     return Indeterminate;
                 }
@@ -222,7 +222,7 @@ fn try_result(&mut self,
                     SingleImport { source, .. } => source,
                     GlobImport { .. } => unreachable!(),
                 };
-                match self.resolve_name_in_module(target_module, name, ns, false, false) {
+                match self.resolve_name_in_module(target_module, name, ns, false, None) {
                     Failed(_) => {}
                     _ => return Some(Indeterminate),
                 }
@@ -495,8 +495,11 @@ fn resolve_import(&mut self, directive: &'b ImportDirective<'b>) -> ResolveResul
         };
 
         // We need to resolve both namespaces for this to succeed.
-        let value_result = self.resolve_name_in_module(target_module, source, ValueNS, false, true);
-        let type_result = self.resolve_name_in_module(target_module, source, TypeNS, false, true);
+        let span = directive.span;
+        let value_result =
+            self.resolve_name_in_module(target_module, source, ValueNS, false, Some(span));
+        let type_result =
+            self.resolve_name_in_module(target_module, source, TypeNS, false, Some(span));
 
         let mut privacy_error = true;
         for &(ns, result, determined) in &[(ValueNS, &value_result, value_determined),