mirror of
https://github.com/rust-lang/rust-clippy
synced 2024-11-30 08:30:45 +00:00
58027e2657
Fixes #12751 changelog: Fix [`redundant_slicing`] when the slice is behind a mutable reference
32 lines
767 B
Rust
32 lines
767 B
Rust
#![warn(clippy::deref_by_slicing)]
|
|
#![allow(clippy::borrow_deref_ref)]
|
|
|
|
use std::io::Read;
|
|
|
|
fn main() {
|
|
let mut vec = vec![0];
|
|
let _ = &vec[..];
|
|
let _ = &mut vec[..];
|
|
|
|
let ref_vec = &mut vec;
|
|
let _ = &ref_vec[..];
|
|
let mut_slice = &mut ref_vec[..];
|
|
let _ = &mut mut_slice[..]; // Err, re-borrows slice
|
|
|
|
let s = String::new();
|
|
let _ = &s[..];
|
|
|
|
static S: &[u8] = &[0, 1, 2];
|
|
let _ = &mut &S[..]; // Err, re-borrows slice
|
|
|
|
let slice: &[u32] = &[0u32, 1u32];
|
|
let slice_ref = &slice;
|
|
let _ = &slice_ref[..]; // Err, derefs slice
|
|
|
|
let bytes: &[u8] = &[];
|
|
let _ = (&bytes[..]).read_to_end(&mut vec![]).unwrap(); // Err, re-borrows slice
|
|
|
|
// issue 12751
|
|
let a = &mut [1, 2, 3][..];
|
|
let _ = &a[..];
|
|
}
|