summaryrefslogtreecommitdiffstats
path: root/src/test/ui/traits/overlap-permitted-for-marker-traits.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/ui/traits/overlap-permitted-for-marker-traits.rs')
-rw-r--r--src/test/ui/traits/overlap-permitted-for-marker-traits.rs28
1 files changed, 28 insertions, 0 deletions
diff --git a/src/test/ui/traits/overlap-permitted-for-marker-traits.rs b/src/test/ui/traits/overlap-permitted-for-marker-traits.rs
new file mode 100644
index 000000000..00823d13b
--- /dev/null
+++ b/src/test/ui/traits/overlap-permitted-for-marker-traits.rs
@@ -0,0 +1,28 @@
+// run-pass
+// Tests for RFC 1268: we allow overlapping impls of marker traits,
+// that is, traits without items. In this case, a type `T` is
+// `MyMarker` if it is either `Debug` or `Display`.
+
+#![feature(marker_trait_attr)]
+#![feature(negative_impls)]
+
+use std::fmt::{Debug, Display};
+
+#[marker]
+trait MyMarker {}
+
+impl<T: Debug> MyMarker for T {}
+impl<T: Display> MyMarker for T {}
+
+fn foo<T: MyMarker>(t: T) -> T {
+ t
+}
+
+fn main() {
+ // Debug && Display:
+ assert_eq!(1, foo(1));
+ assert_eq!(2.0, foo(2.0));
+
+ // Debug && !Display:
+ assert_eq!(vec![1], foo(vec![1]));
+}