//@build-fail //! Make sure that monomorphization-time const errors from `static_assert` take priority over the //! error from simd_extract. Basically this checks that if a const fails to evaluate in some //! function, we don't bother codegen'ing the function. #![feature(generic_arg_infer)] #![feature(core_intrinsics)] #![feature(repr_simd)] use std::intrinsics::simd::*; #[repr(simd)] #[allow(non_camel_case_types)] struct int8x4_t([u8; 4]); fn get_elem(a: int8x4_t) -> u8 { const { assert!(LANE < 4); } // the error should be here... //~^ ERROR failed //~| assertion failed unsafe { simd_extract(a, LANE) } // ...not here } fn main() { get_elem::<4>(int8x4_t([0, 0, 0, 0])); }