mirror of
https://github.com/rust-lang/rust.git
synced 2025-02-27 14:24:08 +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
|
// option. This file may not be copied, modified, or distributed
|
||||||
// except according to those terms.
|
// except according to those terms.
|
||||||
|
|
||||||
|
use std::fmt::{Debug, Display};
|
||||||
|
|
||||||
trait MyMarker {}
|
trait MyMarker {}
|
||||||
|
|
||||||
impl<T> MyMarker for T {}
|
impl<T: Display> MyMarker for T {}
|
||||||
impl<T> MyMarker for Vec<T> {}
|
impl<T: Debug> MyMarker for T {}
|
||||||
//~^ ERROR E0119
|
//~^ ERROR E0119
|
||||||
|
|
||||||
fn main() {}
|
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
|
// option. This file may not be copied, modified, or distributed
|
||||||
// except according to those terms.
|
// 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(overlapping_marker_traits)]
|
||||||
#![feature(optin_builtin_traits)]
|
#![feature(optin_builtin_traits)]
|
||||||
|
|
||||||
|
use std::fmt::{Debug, Display};
|
||||||
|
|
||||||
trait MyMarker {}
|
trait MyMarker {}
|
||||||
|
|
||||||
impl<T: Copy> MyMarker for T {}
|
impl<T: Debug> MyMarker for T {}
|
||||||
impl<T: Eq> MyMarker for T {}
|
impl<T: Display> MyMarker for T {}
|
||||||
|
|
||||||
struct MyStruct;
|
|
||||||
impl !Send for MyStruct {}
|
|
||||||
impl !Send for MyStruct {}
|
|
||||||
|
|
||||||
fn foo<T: MyMarker>(t: T) -> T {
|
fn foo<T: MyMarker>(t: T) -> T {
|
||||||
t
|
t
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
// Debug && Display:
|
||||||
assert_eq!(1, foo(1));
|
assert_eq!(1, foo(1));
|
||||||
assert_eq!(2.0, foo(2.0));
|
assert_eq!(2.0, foo(2.0));
|
||||||
|
|
||||||
|
// Debug && !Display:
|
||||||
assert_eq!(vec![1], foo(vec![1]));
|
assert_eq!(vec![1], foo(vec![1]));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user