add test ensuring simd codegen checks don't run when a static assertion failed
This commit is contained in:
parent
094a6204f5
commit
39db6a0972
24
tests/ui/simd/const-err-trumps-simd-err.rs
Normal file
24
tests/ui/simd/const-err-trumps-simd-err.rs
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
//@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)]
|
||||||
|
#![feature(inline_const)]
|
||||||
|
use std::intrinsics::simd::*;
|
||||||
|
|
||||||
|
#[repr(simd)]
|
||||||
|
#[allow(non_camel_case_types)]
|
||||||
|
struct int8x4_t(u8,u8,u8,u8);
|
||||||
|
|
||||||
|
fn get_elem<const LANE: u32>(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));
|
||||||
|
}
|
17
tests/ui/simd/const-err-trumps-simd-err.stderr
Normal file
17
tests/ui/simd/const-err-trumps-simd-err.stderr
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
error[E0080]: evaluation of `get_elem::<4>::{constant#0}` failed
|
||||||
|
--> $DIR/const-err-trumps-simd-err.rs:16:13
|
||||||
|
|
|
||||||
|
LL | const { assert!(LANE < 4); } // the error should be here...
|
||||||
|
| ^^^^^^^^^^^^^^^^^ the evaluated program panicked at 'assertion failed: LANE < 4', $DIR/const-err-trumps-simd-err.rs:16:13
|
||||||
|
|
|
||||||
|
= note: this error originates in the macro `assert` (in Nightly builds, run with -Z macro-backtrace for more info)
|
||||||
|
|
||||||
|
note: the above error was encountered while instantiating `fn get_elem::<4>`
|
||||||
|
--> $DIR/const-err-trumps-simd-err.rs:23:5
|
||||||
|
|
|
||||||
|
LL | get_elem::<4>(int8x4_t(0,0,0,0));
|
||||||
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
error: aborting due to 1 previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0080`.
|
Loading…
x
Reference in New Issue
Block a user