2021-09-17 02:55:26 -04:00
|
|
|
#![warn(clippy::uninit_vec)]
|
|
|
|
|
|
|
|
use std::mem::MaybeUninit;
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
// with_capacity() -> set_len() should be detected
|
|
|
|
let mut vec: Vec<u8> = Vec::with_capacity(1000);
|
|
|
|
unsafe {
|
|
|
|
vec.set_len(200);
|
|
|
|
}
|
|
|
|
|
|
|
|
// reserve() -> set_len() should be detected
|
|
|
|
vec.reserve(1000);
|
|
|
|
unsafe {
|
|
|
|
vec.set_len(200);
|
|
|
|
}
|
|
|
|
|
|
|
|
// test when both calls are enclosed in the same unsafe block
|
|
|
|
unsafe {
|
|
|
|
let mut vec: Vec<u8> = Vec::with_capacity(1000);
|
|
|
|
vec.set_len(200);
|
|
|
|
|
|
|
|
vec.reserve(1000);
|
|
|
|
vec.set_len(200);
|
|
|
|
}
|
|
|
|
|
|
|
|
// MaybeUninit-wrapped types should not be detected
|
|
|
|
unsafe {
|
2021-09-17 14:42:32 -04:00
|
|
|
let mut vec: Vec<MaybeUninit<u8>> = Vec::with_capacity(1000);
|
|
|
|
vec.set_len(200);
|
|
|
|
|
|
|
|
let mut vec: Vec<(MaybeUninit<u8>, MaybeUninit<bool>)> = Vec::with_capacity(1000);
|
|
|
|
vec.set_len(200);
|
|
|
|
|
|
|
|
let mut vec: Vec<(MaybeUninit<u8>, [MaybeUninit<bool>; 2])> = Vec::with_capacity(1000);
|
2021-09-17 02:55:26 -04:00
|
|
|
vec.set_len(200);
|
|
|
|
}
|
|
|
|
}
|