crashes: more tests
This commit is contained in:
parent
6de928dce9
commit
5fe70afc8c
7 changed files with 98 additions and 0 deletions
7
tests/crashes/129150.rs
Normal file
7
tests/crashes/129150.rs
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
//@ known-bug: rust-lang/rust#129150
|
||||||
|
//@ only-x86_64
|
||||||
|
use std::arch::x86_64::_mm_blend_ps;
|
||||||
|
|
||||||
|
pub fn main() {
|
||||||
|
_mm_blend_ps(1, 2, &const {} );
|
||||||
|
}
|
7
tests/crashes/129166.rs
Normal file
7
tests/crashes/129166.rs
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
//@ known-bug: rust-lang/rust#129166
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
#[cfg_eval]
|
||||||
|
#[cfg]
|
||||||
|
0
|
||||||
|
}
|
5
tests/crashes/129205.rs
Normal file
5
tests/crashes/129205.rs
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
//@ known-bug: rust-lang/rust#129205
|
||||||
|
|
||||||
|
fn x<T: Copy>() {
|
||||||
|
T::try_from();
|
||||||
|
}
|
11
tests/crashes/129209.rs
Normal file
11
tests/crashes/129209.rs
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
//@ known-bug: rust-lang/rust#129209
|
||||||
|
|
||||||
|
impl<
|
||||||
|
const N: usize = {
|
||||||
|
static || {
|
||||||
|
Foo([0; X]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
> PartialEq for True
|
||||||
|
{
|
||||||
|
}
|
30
tests/crashes/129214.rs
Normal file
30
tests/crashes/129214.rs
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
//@ known-bug: rust-lang/rust#129214
|
||||||
|
//@ compile-flags: -Zvalidate-mir -Copt-level=3 --crate-type=lib
|
||||||
|
|
||||||
|
trait to_str {}
|
||||||
|
|
||||||
|
trait map<T> {
|
||||||
|
fn map<U, F>(&self, f: F) -> Vec<U>
|
||||||
|
where
|
||||||
|
F: FnMut(&Box<usize>) -> U;
|
||||||
|
}
|
||||||
|
impl<T> map<T> for Vec<T> {
|
||||||
|
fn map<U, F>(&self, mut f: F) -> Vec<U>
|
||||||
|
where
|
||||||
|
F: FnMut(&T) -> U,
|
||||||
|
{
|
||||||
|
let mut r = Vec::new();
|
||||||
|
for i in self {
|
||||||
|
r.push(f(i));
|
||||||
|
}
|
||||||
|
r
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn foo<U, T: map<U>>(x: T) -> Vec<String> {
|
||||||
|
x.map(|_e| "hi".to_string())
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn main() {
|
||||||
|
assert_eq!(foo(vec![1]), ["hi".to_string()]);
|
||||||
|
}
|
12
tests/crashes/129216.rs
Normal file
12
tests/crashes/129216.rs
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
//@ known-bug: rust-lang/rust#129216
|
||||||
|
//@ only-linux
|
||||||
|
|
||||||
|
trait Mirror {
|
||||||
|
type Assoc;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct Foo;
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
<Foo as Mirror>::Assoc::new();
|
||||||
|
}
|
26
tests/crashes/129219.rs
Normal file
26
tests/crashes/129219.rs
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
//@ known-bug: rust-lang/rust#129219
|
||||||
|
//@ compile-flags: -Zmir-opt-level=5 -Zvalidate-mir --edition=2018
|
||||||
|
|
||||||
|
use core::marker::Unsize;
|
||||||
|
|
||||||
|
pub trait CastTo<T: ?Sized>: Unsize<T> {}
|
||||||
|
|
||||||
|
impl<T: ?Sized, U: ?Sized> CastTo<T> for U {}
|
||||||
|
|
||||||
|
impl<T: ?Sized> Cast for T {}
|
||||||
|
pub trait Cast {
|
||||||
|
fn cast<T: ?Sized>(&self) -> &T
|
||||||
|
where
|
||||||
|
Self: CastTo<T>,
|
||||||
|
{
|
||||||
|
self
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub trait Foo {}
|
||||||
|
impl Foo for [i32; 0] {}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let x: &dyn Foo = &[];
|
||||||
|
let x = x.cast::<[i32]>();
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue