Skip to content

Commit 44edac2

Browse files
committed
---
yaml --- r: 73697 b: refs/heads/dist-snap c: 13aa188 h: refs/heads/master i: 73695: a50654e v: v3
1 parent 91bc13c commit 44edac2

File tree

3 files changed

+40
-4
lines changed

3 files changed

+40
-4
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@ refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
88
refs/heads/try2: 147ecfdd8221e4a4d4e090486829a06da1e0ca3c
99
refs/heads/incoming: b50030718cf28f2a5a81857a26b57442734fe854
10-
refs/heads/dist-snap: 846545a6e19745dddcbefb1e690a63eea15a0884
10+
refs/heads/dist-snap: 13aa18891c0615f8db193ae61e80fa16f567afd1
1111
refs/tags/release-0.2: c870d2dffb391e14efb05aa27898f1f6333a9596
1212
refs/tags/release-0.3: b5f0d0f648d9a6153664837026ba1be43d3e2503
1313
refs/heads/try3: 9387340aab40a73e8424c48fd42f0c521a4875c0

branches/dist-snap/src/librustc/middle/resolve.rs

Lines changed: 22 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -4595,7 +4595,7 @@ impl Resolver {
45954595
}
45964596

45974597
let name = *path.idents.last();
4598-
match self.resolve_definition_of_name_in_module(containing_module,
4598+
let def = match self.resolve_definition_of_name_in_module(containing_module,
45994599
name,
46004600
namespace,
46014601
xray) {
@@ -4604,9 +4604,28 @@ impl Resolver {
46044604
return None;
46054605
}
46064606
ChildNameDefinition(def) | ImportNameDefinition(def) => {
4607-
return Some(def);
4607+
def
46084608
}
4609-
}
4609+
};
4610+
match containing_module.kind {
4611+
TraitModuleKind | ImplModuleKind => {
4612+
match self.method_map.find(&name) {
4613+
Some(s) => {
4614+
match containing_module.def_id {
4615+
Some(def_id) if s.contains(&def_id) => {
4616+
debug!("containing module was a trait or impl \
4617+
and name was a method -> not resolved");
4618+
return None;
4619+
},
4620+
_ => (),
4621+
}
4622+
},
4623+
None => (),
4624+
}
4625+
},
4626+
_ => (),
4627+
};
4628+
return Some(def);
46104629
}
46114630

46124631
/// Invariant: This must be called only during main resolution, not during
Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
// issue #6698
12+
13+
fn V() -> bool {
14+
std::clone::Clone::clone(true) //~ ERROR error: unresolved name `std::clone::Clone::clone`.
15+
}
16+
17+
fn main() {}

0 commit comments

Comments
 (0)