diff options
| author | Niko Matsakis <niko@alum.mit.edu> | 2017-01-17 18:29:55 -0500 |
|---|---|---|
| committer | Niko Matsakis <niko@alum.mit.edu> | 2017-01-17 18:32:09 -0500 |
| commit | f57d5ad7e11007a50db56ebdbdde3fb7f4efd2c1 (patch) | |
| tree | 250df20e023050352f753b696333f7076260bcbe | |
| parent | 8780962828858c5b858b847430514505497a2b5c (diff) | |
| download | rust-f57d5ad7e11007a50db56ebdbdde3fb7f4efd2c1.tar.gz rust-f57d5ad7e11007a50db56ebdbdde3fb7f4efd2c1.zip | |
check inherent impls of traits for overlap as well
| -rw-r--r-- | src/librustc_typeck/coherence/overlap.rs | 1 | ||||
| -rw-r--r-- | src/test/compile-fail/coherence-overlapping-inherent-impl-trait.rs | 17 |
2 files changed, 18 insertions, 0 deletions
diff --git a/src/librustc_typeck/coherence/overlap.rs b/src/librustc_typeck/coherence/overlap.rs index 08293c1d874..7890ae20ec2 100644 --- a/src/librustc_typeck/coherence/overlap.rs +++ b/src/librustc_typeck/coherence/overlap.rs @@ -102,6 +102,7 @@ impl<'cx, 'tcx, 'v> ItemLikeVisitor<'v> for OverlapChecker<'cx, 'tcx> { match item.node { hir::ItemEnum(..) | hir::ItemStruct(..) | + hir::ItemTrait(..) | hir::ItemUnion(..) => { let type_def_id = self.tcx.map.local_def_id(item.id); self.check_for_overlapping_inherent_impls(type_def_id); diff --git a/src/test/compile-fail/coherence-overlapping-inherent-impl-trait.rs b/src/test/compile-fail/coherence-overlapping-inherent-impl-trait.rs new file mode 100644 index 00000000000..a611b22e93d --- /dev/null +++ b/src/test/compile-fail/coherence-overlapping-inherent-impl-trait.rs @@ -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. + +#![allow(dead_code)] +#![deny(overlapping_inherent_impls)] + +trait C {} +impl C { fn f() {} } //~ ERROR duplicate definitions with name `f` +impl C { fn f() {} } +fn main() { } |
