2014-04-03 13:38:45 +13:00
|
|
|
// Copyright 2014 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.
|
2014-04-08 21:00:20 +12:00
|
|
|
#![feature(struct_variant)]
|
2014-04-03 13:38:45 +13:00
|
|
|
|
2014-05-05 18:56:44 -07:00
|
|
|
|
2014-04-03 13:38:45 +13:00
|
|
|
// Test sized-ness checking in substitution.
|
|
|
|
|
|
|
|
// Unbounded.
|
|
|
|
fn f1<type X>(x: &X) {
|
|
|
|
f1::<X>(x);
|
|
|
|
}
|
|
|
|
fn f2<X>(x: &X) {
|
|
|
|
f1::<X>(x);
|
|
|
|
f2::<X>(x);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Bounded.
|
|
|
|
trait T for type {}
|
|
|
|
fn f3<type X: T>(x: &X) {
|
|
|
|
f3::<X>(x);
|
|
|
|
}
|
|
|
|
fn f4<X: T>(x: &X) {
|
|
|
|
f3::<X>(x);
|
|
|
|
f4::<X>(x);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Self type.
|
|
|
|
trait T2 for type {
|
2014-05-05 18:56:44 -07:00
|
|
|
fn f() -> Box<Self>;
|
2014-04-03 13:38:45 +13:00
|
|
|
}
|
|
|
|
struct S;
|
|
|
|
impl T2 for S {
|
2014-05-05 18:56:44 -07:00
|
|
|
fn f() -> Box<S> {
|
|
|
|
box S
|
2014-04-03 13:38:45 +13:00
|
|
|
}
|
|
|
|
}
|
|
|
|
fn f5<type X: T2>(x: &X) {
|
2014-05-05 18:56:44 -07:00
|
|
|
let _: Box<X> = T2::f();
|
2014-04-03 13:38:45 +13:00
|
|
|
}
|
|
|
|
fn f6<X: T2>(x: &X) {
|
2014-05-05 18:56:44 -07:00
|
|
|
let _: Box<X> = T2::f();
|
2014-04-03 13:38:45 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
trait T3 for type {
|
2014-05-05 18:56:44 -07:00
|
|
|
fn f() -> Box<Self>;
|
2014-04-03 13:38:45 +13:00
|
|
|
}
|
|
|
|
impl T3 for S {
|
2014-05-05 18:56:44 -07:00
|
|
|
fn f() -> Box<S> {
|
|
|
|
box S
|
2014-04-03 13:38:45 +13:00
|
|
|
}
|
|
|
|
}
|
|
|
|
fn f7<type X: T3>(x: &X) {
|
|
|
|
// This is valid, but the unsized bound on X is irrelevant because any type
|
|
|
|
// which implements T3 must have statically known size.
|
2014-05-05 18:56:44 -07:00
|
|
|
let _: Box<X> = T3::f();
|
2014-04-03 13:38:45 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
trait T4<X> {
|
|
|
|
fn m1(x: &T4<X>);
|
|
|
|
fn m2(x: &T5<X>);
|
|
|
|
}
|
|
|
|
trait T5<type X> {
|
2014-04-20 18:53:37 +12:00
|
|
|
// not an error (for now)
|
|
|
|
fn m1(x: &T4<X>);
|
2014-04-03 13:38:45 +13:00
|
|
|
fn m2(x: &T5<X>);
|
|
|
|
}
|
|
|
|
|
|
|
|
trait T6<X: T> {
|
|
|
|
fn m1(x: &T4<X>);
|
|
|
|
fn m2(x: &T5<X>);
|
|
|
|
}
|
|
|
|
trait T7<type X: T> {
|
2014-04-20 18:53:37 +12:00
|
|
|
// not an error (for now)
|
|
|
|
fn m1(x: &T4<X>);
|
2014-04-03 13:38:45 +13:00
|
|
|
fn m2(x: &T5<X>);
|
|
|
|
}
|
|
|
|
|
2014-04-08 21:00:20 +12:00
|
|
|
// The last field in a struct or variant may be unsized
|
|
|
|
struct S2<type X> {
|
|
|
|
f: X,
|
|
|
|
}
|
|
|
|
struct S3<type X> {
|
|
|
|
f1: int,
|
|
|
|
f2: X,
|
|
|
|
}
|
|
|
|
enum E<type X> {
|
|
|
|
V1(X),
|
|
|
|
V2{x: X},
|
|
|
|
V3(int, X),
|
|
|
|
V4{u: int, x: X},
|
|
|
|
}
|
|
|
|
|
2014-04-03 13:38:45 +13:00
|
|
|
pub fn main() {
|
|
|
|
}
|