2014-06-28 15:57:36 -05: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.
|
|
|
|
use core::mem::*;
|
|
|
|
use test::Bencher;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn size_of_basic() {
|
|
|
|
assert_eq!(size_of::<u8>(), 1u);
|
|
|
|
assert_eq!(size_of::<u16>(), 2u);
|
|
|
|
assert_eq!(size_of::<u32>(), 4u);
|
|
|
|
assert_eq!(size_of::<u64>(), 8u);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2014-10-11 11:32:40 -05:00
|
|
|
#[cfg(any(target_arch = "x86",
|
|
|
|
target_arch = "arm",
|
|
|
|
target_arch = "mips",
|
|
|
|
target_arch = "mipsel"))]
|
2014-06-28 15:57:36 -05:00
|
|
|
fn size_of_32() {
|
|
|
|
assert_eq!(size_of::<uint>(), 4u);
|
|
|
|
assert_eq!(size_of::<*const uint>(), 4u);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[cfg(target_arch = "x86_64")]
|
|
|
|
fn size_of_64() {
|
|
|
|
assert_eq!(size_of::<uint>(), 8u);
|
|
|
|
assert_eq!(size_of::<*const uint>(), 8u);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn size_of_val_basic() {
|
|
|
|
assert_eq!(size_of_val(&1u8), 1);
|
|
|
|
assert_eq!(size_of_val(&1u16), 2);
|
|
|
|
assert_eq!(size_of_val(&1u32), 4);
|
|
|
|
assert_eq!(size_of_val(&1u64), 8);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn align_of_basic() {
|
|
|
|
assert_eq!(align_of::<u8>(), 1u);
|
|
|
|
assert_eq!(align_of::<u16>(), 2u);
|
|
|
|
assert_eq!(align_of::<u32>(), 4u);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2014-10-11 11:32:40 -05:00
|
|
|
#[cfg(any(target_arch = "x86",
|
|
|
|
target_arch = "arm",
|
|
|
|
target_arch = "mips",
|
|
|
|
target_arch = "mipsel"))]
|
2014-06-28 15:57:36 -05:00
|
|
|
fn align_of_32() {
|
|
|
|
assert_eq!(align_of::<uint>(), 4u);
|
|
|
|
assert_eq!(align_of::<*const uint>(), 4u);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[cfg(target_arch = "x86_64")]
|
|
|
|
fn align_of_64() {
|
|
|
|
assert_eq!(align_of::<uint>(), 8u);
|
|
|
|
assert_eq!(align_of::<*const uint>(), 8u);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn align_of_val_basic() {
|
|
|
|
assert_eq!(align_of_val(&1u8), 1u);
|
|
|
|
assert_eq!(align_of_val(&1u16), 2u);
|
|
|
|
assert_eq!(align_of_val(&1u32), 4u);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_swap() {
|
|
|
|
let mut x = 31337i;
|
|
|
|
let mut y = 42i;
|
|
|
|
swap(&mut x, &mut y);
|
|
|
|
assert_eq!(x, 42);
|
|
|
|
assert_eq!(y, 31337);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_replace() {
|
|
|
|
let mut x = Some("test".to_string());
|
|
|
|
let y = replace(&mut x, None);
|
|
|
|
assert!(x.is_none());
|
|
|
|
assert!(y.is_some());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_transmute_copy() {
|
|
|
|
assert_eq!(1u, unsafe { transmute_copy(&1i) });
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_transmute() {
|
|
|
|
trait Foo {}
|
|
|
|
impl Foo for int {}
|
|
|
|
|
|
|
|
let a = box 100i as Box<Foo>;
|
|
|
|
unsafe {
|
|
|
|
let x: ::core::raw::TraitObject = transmute(a);
|
|
|
|
assert!(*(x.data as *const int) == 100);
|
|
|
|
let _x: Box<Foo> = transmute(x);
|
|
|
|
}
|
|
|
|
|
|
|
|
unsafe {
|
2014-10-05 05:11:17 -05:00
|
|
|
assert!(vec![76u8] == transmute("L".to_string()));
|
2014-06-28 15:57:36 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// FIXME #13642 (these benchmarks should be in another place)
|
|
|
|
/// Completely miscellaneous language-construct benchmarks.
|
|
|
|
// Static/dynamic method dispatch
|
|
|
|
|
|
|
|
struct Struct {
|
|
|
|
field: int
|
|
|
|
}
|
|
|
|
|
|
|
|
trait Trait {
|
|
|
|
fn method(&self) -> int;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Trait for Struct {
|
|
|
|
fn method(&self) -> int {
|
|
|
|
self.field
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn trait_vtable_method_call(b: &mut Bencher) {
|
|
|
|
let s = Struct { field: 10 };
|
|
|
|
let t = &s as &Trait;
|
|
|
|
b.iter(|| {
|
|
|
|
t.method()
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn trait_static_method_call(b: &mut Bencher) {
|
|
|
|
let s = Struct { field: 10 };
|
|
|
|
b.iter(|| {
|
|
|
|
s.method()
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Overhead of various match forms
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn match_option_some(b: &mut Bencher) {
|
|
|
|
let x = Some(10i);
|
|
|
|
b.iter(|| {
|
|
|
|
match x {
|
|
|
|
Some(y) => y,
|
|
|
|
None => 11
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn match_vec_pattern(b: &mut Bencher) {
|
|
|
|
let x = [1i,2,3,4,5,6];
|
|
|
|
b.iter(|| {
|
|
|
|
match x {
|
|
|
|
[1,2,3,..] => 10i,
|
|
|
|
_ => 11i,
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|