Skip to content

Commit c17ff80

Browse files
committed
auto merge of #7267 : luqmana/rust/issue-5792, r=cmr
Fixes #5792
2 parents 2b581c1 + 41e90f2 commit c17ff80

File tree

2 files changed

+28
-9
lines changed

2 files changed

+28
-9
lines changed

src/librustc/middle/resolve.rs

Lines changed: 11 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1415,24 +1415,26 @@ impl Resolver {
14151415
(ReducedGraphParent,
14161416
vt<ReducedGraphParent>)) {
14171417
let ident = variant.node.name;
1418-
let (child, _) = self.add_child(ident, parent, ForbidDuplicateValues,
1419-
variant.span);
1420-
1421-
let privacy;
1422-
match variant.node.vis {
1423-
public => privacy = Public,
1424-
private => privacy = Private,
1425-
inherited => privacy = parent_privacy
1426-
}
1418+
1419+
let privacy =
1420+
match variant.node.vis {
1421+
public => Public,
1422+
private => Private,
1423+
inherited => parent_privacy
1424+
};
14271425

14281426
match variant.node.kind {
14291427
tuple_variant_kind(_) => {
1428+
let (child, _) = self.add_child(ident, parent, ForbidDuplicateValues,
1429+
variant.span);
14301430
child.define_value(privacy,
14311431
def_variant(item_id,
14321432
local_def(variant.node.id)),
14331433
variant.span);
14341434
}
14351435
struct_variant_kind(_) => {
1436+
let (child, _) = self.add_child(ident, parent, ForbidDuplicateTypesAndValues,
1437+
variant.span);
14361438
child.define_type(privacy,
14371439
def_variant(item_id,
14381440
local_def(variant.node.id)),
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+
enum Foo { C { a: int, b: int } }
12+
struct C { a: int, b: int } //~ ERROR error: duplicate definition of type `C`
13+
14+
struct A { x: int }
15+
enum Bar { A { x: int } } //~ ERROR error: duplicate definition of type `A`
16+
17+
fn main() {}

0 commit comments

Comments
 (0)