Skip to content

Commit b1e08b7

Browse files
committed
---
yaml --- r: 63588 b: refs/heads/snap-stage3 c: c17ff80 h: refs/heads/master v: v3
1 parent cce1f68 commit b1e08b7

File tree

3 files changed

+29
-10
lines changed

3 files changed

+29
-10
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
---
22
refs/heads/master: 2d28d645422c1617be58c8ca7ad9a457264ca850
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
4-
refs/heads/snap-stage3: 2b581c17b56eb8cff8a2048519846d1abfb726bd
4+
refs/heads/snap-stage3: c17ff80e01d326028366e9268248628e4667dfcd
55
refs/heads/try: 7b78b52e602bb3ea8174f9b2006bff3315f03ef9
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b

branches/snap-stage3/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)