2023-03-11 05:44:18 -06:00
|
|
|
#![allow(
|
|
|
|
clippy::deref_addrof,
|
|
|
|
dead_code,
|
|
|
|
unused,
|
|
|
|
clippy::no_effect,
|
|
|
|
clippy::unnecessary_struct_initialization
|
|
|
|
)]
|
2018-10-27 12:31:47 -05:00
|
|
|
#![warn(clippy::unnecessary_operation)]
|
|
|
|
|
2023-12-08 07:33:28 -06:00
|
|
|
use std::fmt::Display;
|
|
|
|
use std::ops::Shl;
|
|
|
|
|
2018-10-27 12:31:47 -05:00
|
|
|
struct Tuple(i32);
|
|
|
|
struct Struct {
|
2018-12-09 16:26:16 -06:00
|
|
|
field: i32,
|
2018-10-27 12:31:47 -05:00
|
|
|
}
|
|
|
|
enum Enum {
|
|
|
|
Tuple(i32),
|
|
|
|
Struct { field: i32 },
|
|
|
|
}
|
|
|
|
struct DropStruct {
|
2018-12-09 16:26:16 -06:00
|
|
|
field: i32,
|
2018-10-27 12:31:47 -05:00
|
|
|
}
|
|
|
|
impl Drop for DropStruct {
|
|
|
|
fn drop(&mut self) {}
|
|
|
|
}
|
|
|
|
struct DropTuple(i32);
|
|
|
|
impl Drop for DropTuple {
|
|
|
|
fn drop(&mut self) {}
|
|
|
|
}
|
|
|
|
enum DropEnum {
|
|
|
|
Tuple(i32),
|
|
|
|
Struct { field: i32 },
|
|
|
|
}
|
|
|
|
impl Drop for DropEnum {
|
|
|
|
fn drop(&mut self) {}
|
|
|
|
}
|
|
|
|
struct FooString {
|
|
|
|
s: String,
|
|
|
|
}
|
|
|
|
|
2018-12-09 16:26:16 -06:00
|
|
|
fn get_number() -> i32 {
|
|
|
|
0
|
|
|
|
}
|
2019-09-25 12:49:56 -05:00
|
|
|
|
2024-05-23 21:24:54 -05:00
|
|
|
const fn get_usize() -> usize {
|
2019-09-25 12:49:56 -05:00
|
|
|
0
|
|
|
|
}
|
2018-12-09 16:26:16 -06:00
|
|
|
fn get_struct() -> Struct {
|
|
|
|
Struct { field: 0 }
|
|
|
|
}
|
|
|
|
fn get_drop_struct() -> DropStruct {
|
|
|
|
DropStruct { field: 0 }
|
|
|
|
}
|
2018-10-27 12:31:47 -05:00
|
|
|
|
2023-12-08 07:33:28 -06:00
|
|
|
struct Cout;
|
|
|
|
|
|
|
|
impl<T> Shl<T> for Cout
|
|
|
|
where
|
|
|
|
T: Display,
|
|
|
|
{
|
|
|
|
type Output = Self;
|
|
|
|
fn shl(self, rhs: T) -> Self::Output {
|
|
|
|
println!("{}", rhs);
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-27 12:31:47 -05:00
|
|
|
fn main() {
|
|
|
|
Tuple(get_number());
|
|
|
|
Struct { field: get_number() };
|
|
|
|
Struct { ..get_struct() };
|
|
|
|
Enum::Tuple(get_number());
|
|
|
|
Enum::Struct { field: get_number() };
|
|
|
|
5 + get_number();
|
|
|
|
*&get_number();
|
|
|
|
&get_number();
|
|
|
|
(5, 6, get_number());
|
|
|
|
get_number()..;
|
|
|
|
..get_number();
|
|
|
|
5..get_number();
|
|
|
|
[42, get_number()];
|
2019-09-25 12:49:56 -05:00
|
|
|
[42, 55][get_usize()];
|
2018-10-27 12:31:47 -05:00
|
|
|
(42, get_number()).1;
|
|
|
|
[get_number(); 55];
|
2019-09-25 12:49:56 -05:00
|
|
|
[42; 55][get_usize()];
|
2018-12-09 16:26:16 -06:00
|
|
|
{
|
|
|
|
get_number()
|
|
|
|
};
|
|
|
|
FooString {
|
|
|
|
s: String::from("blah"),
|
|
|
|
};
|
2018-10-27 12:31:47 -05:00
|
|
|
|
|
|
|
// Do not warn
|
|
|
|
DropTuple(get_number());
|
|
|
|
DropStruct { field: get_number() };
|
|
|
|
DropStruct { field: get_number() };
|
|
|
|
DropStruct { ..get_drop_struct() };
|
|
|
|
DropEnum::Tuple(get_number());
|
|
|
|
DropEnum::Struct { field: get_number() };
|
2022-12-01 11:29:38 -06:00
|
|
|
|
|
|
|
// Issue #9954
|
|
|
|
fn one() -> i8 {
|
|
|
|
1
|
|
|
|
}
|
|
|
|
macro_rules! use_expr {
|
|
|
|
($($e:expr),*) => {{ $($e;)* }}
|
|
|
|
}
|
|
|
|
use_expr!(isize::MIN / -(one() as isize), i8::MIN / -one());
|
2023-12-08 07:33:28 -06:00
|
|
|
|
|
|
|
// Issue #11885
|
|
|
|
Cout << 16;
|
2024-01-31 15:09:55 -06:00
|
|
|
|
|
|
|
// Issue #11575
|
|
|
|
// Bad formatting is required to trigger the bug
|
|
|
|
#[rustfmt::skip]
|
|
|
|
'label: {
|
|
|
|
break 'label
|
|
|
|
};
|
2024-05-23 21:24:54 -05:00
|
|
|
let () = const {
|
|
|
|
[42, 55][get_usize()];
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
const _: () = {
|
|
|
|
[42, 55][get_usize()];
|
|
|
|
};
|
|
|
|
|
|
|
|
const fn foo() {
|
|
|
|
[42, 55][get_usize()];
|
2024-06-08 04:39:17 -05:00
|
|
|
//~^ ERROR: unnecessary operation
|
2018-10-27 12:31:47 -05:00
|
|
|
}
|