Skip to content

Commit

Permalink
auto merge of #7029 : luqmana/rust/issue-4228, r=catamorphism
Browse files Browse the repository at this point in the history
Fixes #4228
  • Loading branch information
bors committed Jun 9, 2013
2 parents 94f72dd + 0bf6d9e commit 9bcf911
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 17 deletions.
44 changes: 27 additions & 17 deletions src/librustc/middle/resolve.rs
Expand Up @@ -409,6 +409,7 @@ pub enum ParentLink {
}

/// The type of module this is.
#[deriving(Eq)]
pub enum ModuleKind {
NormalModuleKind,
ExternModuleKind,
Expand Down Expand Up @@ -1228,25 +1229,34 @@ impl Resolver {
match (trait_ref_opt, ty) {
(None, @Ty { node: ty_path(path, _), _ }) if
has_static_methods && path.idents.len() == 1 => {
// Create the module.
let name = path_to_ident(path);
let (name_bindings, new_parent) =
self.add_child(name,
parent,
ForbidDuplicateModules,
sp);

let parent_link = self.get_parent_link(new_parent,
ident);
let def_id = local_def(item.id);
name_bindings.define_module(Public,
parent_link,
Some(def_id),
ImplModuleKind,
sp);

let new_parent = ModuleReducedGraphParent(
name_bindings.get_module());
let new_parent = match parent.children.find(&name) {
// It already exists
Some(&child) if child.get_module_if_available().is_some() &&
child.get_module().kind == ImplModuleKind => {
ModuleReducedGraphParent(child.get_module())
}
// Create the module
_ => {
let (name_bindings, new_parent) =
self.add_child(name,
parent,
ForbidDuplicateModules,
sp);

let parent_link = self.get_parent_link(new_parent,
ident);
let def_id = local_def(item.id);
name_bindings.define_module(Public,
parent_link,
Some(def_id),
ImplModuleKind,
sp);

ModuleReducedGraphParent(name_bindings.get_module())
}
};

// For each static method...
for methods.each |method| {
Expand Down
23 changes: 23 additions & 0 deletions src/test/run-pass/issue-4228.rs
@@ -0,0 +1,23 @@
// Copyright 2013 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.

struct Foo;

impl Foo {
fn first() {}
}
impl Foo {
fn second() {}
}

pub fn main() {
Foo::first();
Foo::second();
}

0 comments on commit 9bcf911

Please sign in to comment.