// run-pass #![feature(generic_const_exprs)] #![feature(transmute_generic_consts)] #![allow(incomplete_features)] fn transpose(v: [[u32;H]; W]) -> [[u32; W]; H] { unsafe { std::mem::transmute(v) } } fn ident(v: [[u32; H]; W]) -> [[u32; H]; W] { unsafe { std::mem::transmute(v) } } fn flatten(v: [[u32; H]; W]) -> [u32; W * H] { unsafe { std::mem::transmute(v) } } fn coagulate(v: [u32; H*W]) -> [[u32; W];H] { unsafe { std::mem::transmute(v) } } fn flatten_3d( v: [[[u32; D]; H]; W] ) -> [u32; D * W * H] { unsafe { std::mem::transmute(v) } } fn flatten_somewhat( v: [[[u32; D]; H]; W] ) -> [[u32; D * W]; H] { unsafe { std::mem::transmute(v) } } fn known_size(v: [u16; L]) -> [u8; L * 2] { unsafe { std::mem::transmute(v) } } fn condense_bytes(v: [u8; L * 2]) -> [u16; L] { unsafe { std::mem::transmute(v) } } fn singleton_each(v: [u8; L]) -> [[u8;1]; L] { unsafe { std::mem::transmute(v) } } fn transpose_with_const( v: [[u32; 2 * H]; W + W] ) -> [[u32; W + W]; 2 * H] { unsafe { std::mem::transmute(v) } } fn main() { let _ = transpose([[0; 8]; 16]); let _ = transpose_with_const::<8,4>([[0; 8]; 16]); let _ = ident([[0; 8]; 16]); let _ = flatten([[0; 13]; 5]); let _: [[_; 5]; 13] = coagulate([0; 65]); let _ = flatten_3d([[[0; 3]; 13]; 5]); let _ = flatten_somewhat([[[0; 3]; 13]; 5]); let _ = known_size([16; 13]); let _: [u16; 5] = condense_bytes([16u8; 10]); let _ = singleton_each([16; 10]); }