3f880912e9
It looks like many of these tests are already disabled on emscripten, which also doesn't seem to support environment variables and subprocess spawning. Just add a similar tag for CloudABI. While there, sort some of the lists of operating systems alphabetically.
117 lines
2.8 KiB
Rust
117 lines
2.8 KiB
Rust
// Copyright 2012-2015 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.
|
|
|
|
// ignore-wasm32-bare seems unimportant to test
|
|
|
|
// Issue #2303
|
|
|
|
#![feature(intrinsics)]
|
|
|
|
use std::mem;
|
|
|
|
mod rusti {
|
|
extern "rust-intrinsic" {
|
|
pub fn pref_align_of<T>() -> usize;
|
|
pub fn min_align_of<T>() -> usize;
|
|
}
|
|
}
|
|
|
|
// This is the type with the questionable alignment
|
|
#[derive(Debug)]
|
|
struct Inner {
|
|
c64: u64
|
|
}
|
|
|
|
// This is the type that contains the type with the
|
|
// questionable alignment, for testing
|
|
#[derive(Debug)]
|
|
struct Outer {
|
|
c8: u8,
|
|
t: Inner
|
|
}
|
|
|
|
|
|
#[cfg(any(target_os = "cloudabi",
|
|
target_os = "dragonfly",
|
|
target_os = "emscripten",
|
|
target_os = "freebsd",
|
|
target_os = "linux",
|
|
target_os = "macos",
|
|
target_os = "netbsd",
|
|
target_os = "openbsd",
|
|
target_os = "solaris"))]
|
|
mod m {
|
|
#[cfg(target_arch = "x86")]
|
|
pub mod m {
|
|
pub fn align() -> usize { 4 }
|
|
pub fn size() -> usize { 12 }
|
|
}
|
|
|
|
#[cfg(not(target_arch = "x86"))]
|
|
pub mod m {
|
|
pub fn align() -> usize { 8 }
|
|
pub fn size() -> usize { 16 }
|
|
}
|
|
}
|
|
|
|
#[cfg(target_os = "bitrig")]
|
|
mod m {
|
|
#[cfg(target_arch = "x86_64")]
|
|
pub mod m {
|
|
pub fn align() -> usize { 8 }
|
|
pub fn size() -> usize { 16 }
|
|
}
|
|
}
|
|
|
|
#[cfg(target_os = "windows")]
|
|
mod m {
|
|
#[cfg(target_arch = "x86")]
|
|
pub mod m {
|
|
pub fn align() -> usize { 8 }
|
|
pub fn size() -> usize { 16 }
|
|
}
|
|
|
|
#[cfg(target_arch = "x86_64")]
|
|
pub mod m {
|
|
pub fn align() -> usize { 8 }
|
|
pub fn size() -> usize { 16 }
|
|
}
|
|
}
|
|
|
|
#[cfg(target_os = "android")]
|
|
mod m {
|
|
#[cfg(any(target_arch = "arm", target_arch = "aarch64"))]
|
|
pub mod m {
|
|
pub fn align() -> usize { 8 }
|
|
pub fn size() -> usize { 16 }
|
|
}
|
|
}
|
|
|
|
pub fn main() {
|
|
unsafe {
|
|
let x = Outer {c8: 22, t: Inner {c64: 44}};
|
|
|
|
let y = format!("{:?}", x);
|
|
|
|
println!("align inner = {:?}", rusti::min_align_of::<Inner>());
|
|
println!("size outer = {:?}", mem::size_of::<Outer>());
|
|
println!("y = {:?}", y);
|
|
|
|
// per clang/gcc the alignment of `Inner` is 4 on x86.
|
|
assert_eq!(rusti::min_align_of::<Inner>(), m::m::align());
|
|
|
|
// per clang/gcc the size of `Outer` should be 12
|
|
// because `Inner`s alignment was 4.
|
|
assert_eq!(mem::size_of::<Outer>(), m::m::size());
|
|
|
|
assert_eq!(y, "Outer { c8: 22, t: Inner { c64: 44 } }".to_string());
|
|
}
|
|
}
|