140 lines
3.4 KiB
Rust
Raw Normal View History

fn make_vec() -> Vec<u8> {
2016-03-21 02:41:07 -06:00
let mut v = Vec::with_capacity(4);
2016-03-20 20:18:09 -06:00
v.push(1);
v.push(2);
v
}
fn make_vec_macro() -> Vec<u8> {
vec![1, 2]
2016-03-21 02:41:22 -06:00
}
2016-03-21 03:19:07 -06:00
fn make_vec_macro_repeat() -> Vec<u8> {
vec![42; 5]
}
fn make_vec_macro_repeat_zeroed() -> Vec<u8> {
vec![0; 7]
}
fn vec_into_iter() -> u8 {
vec![1, 2, 3, 4]
.into_iter()
.map(|x| x * x)
.fold(0, |x, y| x + y)
2016-03-21 03:19:07 -06:00
}
fn vec_into_iter_rev() -> u8 {
vec![1, 2, 3, 4]
.into_iter()
.map(|x| x * x)
.fold(0, |x, y| x + y)
}
2017-07-20 13:20:33 -07:00
fn vec_into_iter_zst() -> usize {
vec![[0u64; 0], [0u64; 0]]
.into_iter()
.rev()
.map(|x| x.len())
.sum()
}
fn vec_into_iter_rev_zst() -> usize {
vec![[0u64; 0], [0u64; 0]]
.into_iter()
.rev()
2017-07-20 13:20:33 -07:00
.map(|x| x.len())
.sum()
}
fn vec_iter_and_mut() {
let mut v = vec![1,2,3,4];
for i in v.iter_mut() {
*i += 1;
}
assert_eq!(v.iter().sum::<i32>(), 2+3+4+5);
}
fn vec_iter_and_mut_rev() {
let mut v = vec![1,2,3,4];
for i in v.iter_mut().rev() {
*i += 1;
}
assert_eq!(v.iter().sum::<i32>(), 2+3+4+5);
}
fn vec_reallocate() -> Vec<u8> {
let mut v = vec![1, 2];
v.push(3);
v.push(4);
v.push(5);
v
}
2016-04-22 10:34:14 +02:00
2020-03-23 13:02:02 +01:00
fn vec_push_ptr_stable() {
let mut v = Vec::with_capacity(10);
v.push(0);
2020-03-30 13:27:59 +02:00
let v0 = unsafe { &mut *(&mut v[0] as *mut _) }; // laundering the lifetime -- we take care that `v` does not reallocate, so that's okay.
2020-03-23 13:02:02 +01:00
v.push(1);
let _val = *v0;
}
fn vec_extend_ptr_stable() {
let mut v = Vec::with_capacity(10);
v.push(0);
2020-03-30 13:27:59 +02:00
let v0 = unsafe { &mut *(&mut v[0] as *mut _) }; // laundering the lifetime -- we take care that `v` does not reallocate, so that's okay.
2020-03-30 10:41:44 +02:00
// `slice::Iter` (with `T: Copy`) specialization
2020-03-23 13:02:02 +01:00
v.extend(&[1]);
let _val = *v0;
2020-03-30 10:41:44 +02:00
// `vec::IntoIter` specialization
2020-03-23 13:02:02 +01:00
v.extend(vec![2]);
let _val = *v0;
2020-03-30 10:41:44 +02:00
// `TrustedLen` specialization
2020-03-23 13:02:02 +01:00
v.extend(std::iter::once(3));
let _val = *v0;
2020-03-30 10:41:44 +02:00
// base case
v.extend(std::iter::once(3).filter(|_| true));
let _val = *v0;
}
fn vec_truncate_ptr_stable() {
let mut v = vec![0; 10];
2020-03-30 13:27:59 +02:00
let v0 = unsafe { &mut *(&mut v[0] as *mut _) }; // laundering the lifetime -- we take care that `v` does not reallocate, so that's okay.
2020-03-30 10:41:44 +02:00
v.truncate(5);
let _val = *v0;
2020-03-23 13:02:02 +01:00
}
fn push_str_ptr_stable() {
let mut buf = String::with_capacity(11);
buf.push_str("hello");
let hello: &str = unsafe { &*(buf.as_str() as *const _) }; // laundering the lifetime -- we take care that `buf` does not reallocate, so that's okay.
buf.push_str(" world");
assert_eq!(format!("{}", hello), "hello");
}
2016-04-22 14:38:46 +02:00
fn main() {
assert_eq!(vec_reallocate().len(), 5);
2016-04-22 14:38:46 +02:00
assert_eq!(vec_into_iter(), 30);
assert_eq!(vec_into_iter_rev(), 30);
vec_iter_and_mut();
2017-07-20 13:20:33 -07:00
assert_eq!(vec_into_iter_zst(), 0);
assert_eq!(vec_into_iter_rev_zst(), 0);
vec_iter_and_mut_rev();
2016-04-22 14:38:46 +02:00
assert_eq!(make_vec().capacity(), 4);
assert_eq!(make_vec_macro(), [1, 2]);
assert_eq!(make_vec_macro_repeat(), [42; 5]);
assert_eq!(make_vec_macro_repeat_zeroed(), [0; 7]);
// Test interesting empty slice comparison
// (one is a real pointer, one an integer pointer).
assert_eq!((200..-5).step_by(1).collect::<Vec<isize>>(), []);
2020-03-23 13:02:02 +01:00
2020-04-05 18:28:05 +02:00
// liballoc has a more extensive test of this, but let's at least do a smoke test here.
2020-03-23 13:02:02 +01:00
vec_push_ptr_stable();
vec_extend_ptr_stable();
2020-03-30 10:41:44 +02:00
vec_truncate_ptr_stable();
push_str_ptr_stable();
2016-04-22 14:38:46 +02:00
}