2015-01-04 18:47:58 +02: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.
|
|
|
|
|
2015-03-22 13:13:15 -07:00
|
|
|
// pretty-expanded FIXME #23616
|
|
|
|
|
2015-03-05 18:33:58 -08:00
|
|
|
#![feature(collections, rand)]
|
2015-01-04 18:47:58 +02:00
|
|
|
|
2015-01-15 09:46:12 +02:00
|
|
|
use std::borrow::{Cow, IntoCow};
|
2015-02-18 14:39:37 -08:00
|
|
|
use std::collections::BitVec;
|
2015-01-04 18:47:58 +02:00
|
|
|
use std::default::Default;
|
|
|
|
use std::iter::FromIterator;
|
2015-01-15 09:46:12 +02:00
|
|
|
use std::ops::Add;
|
2015-01-04 18:47:58 +02:00
|
|
|
use std::option::IntoIter as OptionIter;
|
|
|
|
use std::rand::Rand;
|
|
|
|
use std::rand::XorShiftRng as DummyRng;
|
|
|
|
// FIXME the glob std::prelude::*; import of Vec is missing non-static inherent methods.
|
|
|
|
use std::vec::Vec;
|
|
|
|
|
|
|
|
#[derive(PartialEq, Eq)]
|
|
|
|
struct Newt<T>(T);
|
|
|
|
|
|
|
|
fn id<T>(x: T) -> T { x }
|
|
|
|
fn eq<T: Eq>(a: T, b: T) -> bool { a == b }
|
|
|
|
fn u8_as_i8(x: u8) -> i8 { x as i8 }
|
2015-02-17 17:41:40 +02:00
|
|
|
fn odd(x: usize) -> bool { x % 2 == 1 }
|
2015-01-04 18:47:58 +02:00
|
|
|
fn dummy_rng() -> DummyRng { DummyRng::new_unseeded() }
|
|
|
|
|
2015-01-15 09:46:12 +02:00
|
|
|
trait Size: Sized {
|
2015-02-17 17:41:40 +02:00
|
|
|
fn size() -> usize { std::mem::size_of::<Self>() }
|
2015-01-15 09:46:12 +02:00
|
|
|
}
|
|
|
|
impl<T> Size for T {}
|
|
|
|
|
2015-01-04 18:47:58 +02:00
|
|
|
macro_rules! tests {
|
2015-01-05 01:51:03 -05:00
|
|
|
($($expr:expr, $ty:ty, ($($test:expr),*);)+) => (pub fn main() {$({
|
2015-01-04 18:47:58 +02:00
|
|
|
const C: $ty = $expr;
|
|
|
|
static S: $ty = $expr;
|
|
|
|
assert!(eq(C($($test),*), $expr($($test),*)));
|
|
|
|
assert!(eq(S($($test),*), $expr($($test),*)));
|
|
|
|
assert!(eq(C($($test),*), S($($test),*)));
|
|
|
|
})+})
|
|
|
|
}
|
|
|
|
|
|
|
|
tests! {
|
|
|
|
// Free function.
|
2015-02-17 17:41:40 +02:00
|
|
|
id, fn(i32) -> i32, (5);
|
|
|
|
id::<i32>, fn(i32) -> i32, (5);
|
2015-01-04 18:47:58 +02:00
|
|
|
|
|
|
|
// Enum variant constructor.
|
2015-02-17 17:41:40 +02:00
|
|
|
Some, fn(i32) -> Option<i32>, (5);
|
|
|
|
Some::<i32>, fn(i32) -> Option<i32>, (5);
|
2015-01-04 18:47:58 +02:00
|
|
|
|
|
|
|
// Tuple struct constructor.
|
2015-02-17 17:41:40 +02:00
|
|
|
Newt, fn(i32) -> Newt<i32>, (5);
|
|
|
|
Newt::<i32>, fn(i32) -> Newt<i32>, (5);
|
2015-01-04 18:47:58 +02:00
|
|
|
|
|
|
|
// Inherent static methods.
|
2015-01-05 01:51:03 -05:00
|
|
|
Vec::new, fn() -> Vec<()>, ();
|
|
|
|
Vec::<()>::new, fn() -> Vec<()>, ();
|
2015-02-17 19:29:13 +02:00
|
|
|
<Vec<()>>::new, fn() -> Vec<()>, ();
|
2015-02-17 17:41:40 +02:00
|
|
|
Vec::with_capacity, fn(usize) -> Vec<()>, (5);
|
|
|
|
Vec::<()>::with_capacity, fn(usize) -> Vec<()>, (5);
|
2015-02-17 19:29:13 +02:00
|
|
|
<Vec<()>>::with_capacity, fn(usize) -> Vec<()>, (5);
|
2015-02-17 17:41:40 +02:00
|
|
|
BitVec::from_fn, fn(usize, fn(usize) -> bool) -> BitVec, (5, odd);
|
|
|
|
BitVec::from_fn::<fn(usize) -> bool>, fn(usize, fn(usize) -> bool) -> BitVec, (5, odd);
|
2015-01-04 18:47:58 +02:00
|
|
|
|
|
|
|
// Inherent non-static method.
|
2015-01-05 01:51:03 -05:00
|
|
|
Vec::map_in_place, fn(Vec<u8>, fn(u8) -> i8) -> Vec<i8>, (vec![b'f', b'o', b'o'], u8_as_i8);
|
|
|
|
Vec::map_in_place::<i8, fn(u8) -> i8>, fn(Vec<u8>, fn(u8) -> i8) -> Vec<i8>,
|
|
|
|
(vec![b'f', b'o', b'o'], u8_as_i8);
|
2015-01-04 18:47:58 +02:00
|
|
|
// FIXME these break with "type parameter might not appear here pointing at `<u8>`.
|
|
|
|
// Vec::<u8>::map_in_place: fn(Vec<u8>, fn(u8) -> i8) -> Vec<i8>
|
2015-01-05 01:51:03 -05:00
|
|
|
// , (vec![b'f', b'o', b'o'], u8_as_i8);
|
2015-01-04 18:47:58 +02:00
|
|
|
// Vec::<u8>::map_in_place::<i8, fn(u8) -> i8>: fn(Vec<u8>, fn(u8) -> i8) -> Vec<i8>
|
2015-01-05 01:51:03 -05:00
|
|
|
// , (vec![b'f', b'o', b'o'], u8_as_i8);
|
2015-01-04 18:47:58 +02:00
|
|
|
|
|
|
|
// Trait static methods.
|
2015-02-17 17:41:40 +02:00
|
|
|
bool::size, fn() -> usize, ();
|
2015-02-17 19:29:13 +02:00
|
|
|
<bool>::size, fn() -> usize, ();
|
2015-02-17 17:41:40 +02:00
|
|
|
<bool as Size>::size, fn() -> usize, ();
|
2015-02-11 09:33:49 +02:00
|
|
|
|
2015-02-17 17:41:40 +02:00
|
|
|
Default::default, fn() -> i32, ();
|
|
|
|
i32::default, fn() -> i32, ();
|
2015-02-17 19:29:13 +02:00
|
|
|
<i32>::default, fn() -> i32, ();
|
2015-02-17 17:41:40 +02:00
|
|
|
<i32 as Default>::default, fn() -> i32, ();
|
2015-02-11 09:33:49 +02:00
|
|
|
|
2015-02-17 17:41:40 +02:00
|
|
|
Rand::rand, fn(&mut DummyRng) -> i32, (&mut dummy_rng());
|
|
|
|
i32::rand, fn(&mut DummyRng) -> i32, (&mut dummy_rng());
|
2015-02-17 19:29:13 +02:00
|
|
|
<i32>::rand, fn(&mut DummyRng) -> i32, (&mut dummy_rng());
|
2015-02-17 17:41:40 +02:00
|
|
|
<i32 as Rand>::rand, fn(&mut DummyRng) -> i32, (&mut dummy_rng());
|
|
|
|
Rand::rand::<DummyRng>, fn(&mut DummyRng) -> i32, (&mut dummy_rng());
|
|
|
|
i32::rand::<DummyRng>, fn(&mut DummyRng) -> i32, (&mut dummy_rng());
|
2015-02-17 19:29:13 +02:00
|
|
|
<i32>::rand::<DummyRng>, fn(&mut DummyRng) -> i32, (&mut dummy_rng());
|
2015-02-17 17:41:40 +02:00
|
|
|
<i32 as Rand>::rand::<DummyRng>, fn(&mut DummyRng) -> i32, (&mut dummy_rng());
|
2015-01-04 18:47:58 +02:00
|
|
|
|
|
|
|
// Trait non-static methods.
|
2015-02-17 17:41:40 +02:00
|
|
|
Clone::clone, fn(&i32) -> i32, (&5);
|
|
|
|
i32::clone, fn(&i32) -> i32, (&5);
|
2015-02-17 19:29:13 +02:00
|
|
|
<i32>::clone, fn(&i32) -> i32, (&5);
|
2015-02-17 17:41:40 +02:00
|
|
|
<i32 as Clone>::clone, fn(&i32) -> i32, (&5);
|
2015-02-11 09:33:49 +02:00
|
|
|
|
2015-02-17 17:41:40 +02:00
|
|
|
FromIterator::from_iter, fn(OptionIter<i32>) -> Vec<i32>, (Some(5).into_iter());
|
|
|
|
Vec::from_iter, fn(OptionIter<i32>) -> Vec<i32>, (Some(5).into_iter());
|
2015-02-17 19:29:13 +02:00
|
|
|
<Vec<_>>::from_iter, fn(OptionIter<i32>) -> Vec<i32>, (Some(5).into_iter());
|
2015-02-17 17:41:40 +02:00
|
|
|
<Vec<_> as FromIterator<_>>::from_iter, fn(OptionIter<i32>) -> Vec<i32>,
|
2015-01-15 09:46:12 +02:00
|
|
|
(Some(5).into_iter());
|
2015-02-17 17:41:40 +02:00
|
|
|
<Vec<i32> as FromIterator<_>>::from_iter, fn(OptionIter<i32>) -> Vec<i32>,
|
2015-01-15 09:46:12 +02:00
|
|
|
(Some(5).into_iter());
|
2015-02-17 17:41:40 +02:00
|
|
|
FromIterator::from_iter::<OptionIter<i32>>, fn(OptionIter<i32>) -> Vec<i32>,
|
2015-01-15 09:46:12 +02:00
|
|
|
(Some(5).into_iter());
|
2015-02-17 17:41:40 +02:00
|
|
|
<Vec<i32> as FromIterator<_>>::from_iter::<OptionIter<i32>>, fn(OptionIter<i32>) -> Vec<i32>,
|
2015-01-15 09:46:12 +02:00
|
|
|
(Some(5).into_iter());
|
2015-02-11 09:33:49 +02:00
|
|
|
|
2015-01-15 09:46:12 +02:00
|
|
|
Add::add, fn(i32, i32) -> i32, (5, 6);
|
2015-02-11 09:33:49 +02:00
|
|
|
i32::add, fn(i32, i32) -> i32, (5, 6);
|
2015-02-17 19:29:13 +02:00
|
|
|
<i32>::add, fn(i32, i32) -> i32, (5, 6);
|
2015-01-15 09:46:12 +02:00
|
|
|
<i32 as Add<_>>::add, fn(i32, i32) -> i32, (5, 6);
|
|
|
|
<i32 as Add<i32>>::add, fn(i32, i32) -> i32, (5, 6);
|
2015-02-11 09:33:49 +02:00
|
|
|
|
|
|
|
String::into_cow, fn(String) -> Cow<'static, str>,
|
|
|
|
("foo".to_string());
|
2015-02-17 19:29:13 +02:00
|
|
|
<String>::into_cow, fn(String) -> Cow<'static, str>,
|
|
|
|
("foo".to_string());
|
2015-02-11 23:16:32 -08:00
|
|
|
<String as IntoCow<_>>::into_cow, fn(String) -> Cow<'static, str>,
|
2015-01-15 09:46:12 +02:00
|
|
|
("foo".to_string());
|
2015-02-11 23:16:32 -08:00
|
|
|
<String as IntoCow<'static, _>>::into_cow, fn(String) -> Cow<'static, str>,
|
2015-01-15 09:46:12 +02:00
|
|
|
("foo".to_string());
|
2015-01-04 18:47:58 +02:00
|
|
|
}
|