]> git.lizzy.rs Git - rust.git/commitdiff
Fix ICE when variant is used as a part of associated type
authorVadim Petrochenkov <vadim.petrochenkov@gmail.com>
Sun, 8 Jan 2017 13:38:40 +0000 (16:38 +0300)
committerVadim Petrochenkov <vadim.petrochenkov@gmail.com>
Sun, 8 Jan 2017 13:40:50 +0000 (16:40 +0300)
src/librustc_resolve/lib.rs
src/test/compile-fail/resolve-variant-assoc-item.rs [new file with mode: 0644]
src/test/compile-fail/ufcs-partially-resolved.rs

index 39a9194cf5e6002fd29b719ab8d1c9c44a2d11c7..74df14e881d7e43450cb33f2a4a777e09a8b706b 100644 (file)
@@ -2410,13 +2410,15 @@ fn resolve_path(&mut self,
 
             match binding {
                 Ok(binding) => {
+                    let def = binding.def();
+                    let maybe_assoc = opt_ns != Some(MacroNS) && PathSource::Type.is_expected(def);
                     if let Some(next_module) = binding.module() {
                         module = Some(next_module);
-                    } else if binding.def() == Def::Err {
+                    } else if def == Def::Err {
                         return PathResult::NonModule(err_path_resolution());
-                    } else if opt_ns.is_some() && !(opt_ns == Some(MacroNS) && !is_last) {
+                    } else if opt_ns.is_some() && (is_last || maybe_assoc) {
                         return PathResult::NonModule(PathResolution {
-                            base_def: binding.def(),
+                            base_def: def,
                             depth: path.len() - i - 1,
                         });
                     } else {
diff --git a/src/test/compile-fail/resolve-variant-assoc-item.rs b/src/test/compile-fail/resolve-variant-assoc-item.rs
new file mode 100644 (file)
index 0000000..869eed5
--- /dev/null
@@ -0,0 +1,17 @@
+// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+enum E { V }
+use E::V;
+
+fn main() {
+    E::V::associated_item; //~ ERROR failed to resolve. Not a module `V`
+    V::associated_item; //~ ERROR failed to resolve. Not a module `V`
+}
index 5337272343b7d184d85f7ac821befd86b0ffdb62..7e2c97711801d25befb450e3137af9d7c3d11a57 100644 (file)
@@ -55,9 +55,9 @@ fn main() {
     <u8 as E::N>::NN; //~ ERROR unresolved method or associated constant `E::N::NN`
     <u8 as A::N>::NN; //~ ERROR unresolved method or associated constant `A::N::NN`
     let _: <u8 as Tr::Y>::NN; //~ ERROR unresolved associated type `Tr::Y::NN`
-    let _: <u8 as E::Y>::NN; //~ ERROR unresolved associated type `E::Y::NN`
+    let _: <u8 as E::Y>::NN; //~ ERROR failed to resolve. Not a module `Y`
     <u8 as Tr::Y>::NN; //~ ERROR unresolved method or associated constant `Tr::Y::NN`
-    <u8 as E::Y>::NN; //~ ERROR unresolved method or associated constant `E::Y::NN`
+    <u8 as E::Y>::NN; //~ ERROR failed to resolve. Not a module `Y`
 
     let _: <u8 as Dr>::Z; //~ ERROR expected associated type, found method `Dr::Z`
     <u8 as Dr>::X; //~ ERROR expected method or associated constant, found associated type `Dr::X`