mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-31 09:04:18 +00:00
update tests slightly
This commit is contained in:
parent
5a9c25b91e
commit
805704c346
@ -8,10 +8,12 @@
|
||||
// option. This file may not be copied, modified, or distributed
|
||||
// except according to those terms.
|
||||
|
||||
use std::fmt::{Debug, Display};
|
||||
|
||||
trait MyMarker {}
|
||||
|
||||
impl<T> MyMarker for T {}
|
||||
impl<T> MyMarker for Vec<T> {}
|
||||
impl<T: Display> MyMarker for T {}
|
||||
impl<T: Debug> MyMarker for T {}
|
||||
//~^ ERROR E0119
|
||||
|
||||
fn main() {}
|
||||
|
41
src/test/compile-fail/overlap-marker-trait.rs
Normal file
41
src/test/compile-fail/overlap-marker-trait.rs
Normal file
@ -0,0 +1,41 @@
|
||||
// Copyright 2017 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.
|
||||
|
||||
// Test 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`. This test just
|
||||
// checks that we don't consider **all** types to be `MyMarker`. See
|
||||
// also the companion test in
|
||||
// `run-pass/overlap-permitted-for-marker-traits.rs`.
|
||||
|
||||
#![feature(overlapping_marker_traits)]
|
||||
#![feature(optin_builtin_traits)]
|
||||
|
||||
use std::fmt::{Debug, Display};
|
||||
|
||||
trait Marker {}
|
||||
|
||||
impl<T: Debug> Marker for T {}
|
||||
impl<T: Display> Marker for T {}
|
||||
|
||||
fn is_marker<T: Marker>() { }
|
||||
|
||||
struct NotDebugOrDisplay;
|
||||
|
||||
fn main() {
|
||||
// Debug && Display:
|
||||
is_marker::<i32>();
|
||||
|
||||
// Debug && !Display:
|
||||
is_marker::<Vec<i32>>();
|
||||
|
||||
// !Debug && !Display
|
||||
is_marker::<NotDebugOrDisplay>(); //~ ERROR
|
||||
}
|
20
src/test/run-pass/overlap-permitted-for-marker-traits-neg.rs
Normal file
20
src/test/run-pass/overlap-permitted-for-marker-traits-neg.rs
Normal file
@ -0,0 +1,20 @@
|
||||
// Copyright 2017 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.
|
||||
|
||||
#![feature(overlapping_marker_traits)]
|
||||
#![feature(optin_builtin_traits)]
|
||||
|
||||
// Overlapping negative impls for `MyStruct` are permitted:
|
||||
struct MyStruct;
|
||||
impl !Send for MyStruct {}
|
||||
impl !Send for MyStruct {}
|
||||
|
||||
fn main() {
|
||||
}
|
@ -8,24 +8,29 @@
|
||||
// option. This file may not be copied, modified, or distributed
|
||||
// except according to those terms.
|
||||
|
||||
// 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(overlapping_marker_traits)]
|
||||
#![feature(optin_builtin_traits)]
|
||||
|
||||
use std::fmt::{Debug, Display};
|
||||
|
||||
trait MyMarker {}
|
||||
|
||||
impl<T: Copy> MyMarker for T {}
|
||||
impl<T: Eq> MyMarker for T {}
|
||||
|
||||
struct MyStruct;
|
||||
impl !Send for MyStruct {}
|
||||
impl !Send for MyStruct {}
|
||||
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]));
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user