mirror of
https://github.com/rust-lang/rust-clippy
synced 2025-01-09 19:58:44 +00:00
97dc4b22c6
When encountering code such as: ``` Box::new(outer::Inner::default()) ``` clippy would suggest replacing with `Box::<Inner>::default()`, dropping the `outer::` segment. This behavior is incorrect and that commit fixes it. What it does is it checks the contents of the `Box::new` and, if it is of the form `A::B::default`, does a text replacement, inserting `A::B` in the `Box`'s quickfix generic list. If the source does not match that pattern (including `Vec::from(..)` or other `T::new()` calls), we then fallback to the original code. Fixes #11927
113 lines
4.3 KiB
Text
113 lines
4.3 KiB
Text
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:22:32
|
|
|
|
|
LL | let _string: Box<String> = Box::new(Default::default());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::default()`
|
|
|
|
|
= note: `-D clippy::box-default` implied by `-D warnings`
|
|
= help: to override `-D warnings` add `#[allow(clippy::box_default)]`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:23:17
|
|
|
|
|
LL | let _byte = Box::new(u8::default());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<u8>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:24:16
|
|
|
|
|
LL | let _vec = Box::new(Vec::<u8>::new());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<Vec::<u8>>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:25:17
|
|
|
|
|
LL | let _impl = Box::new(ImplementsDefault::default());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<ImplementsDefault>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:26:18
|
|
|
|
|
LL | let _impl2 = Box::new(<ImplementsDefault as Default>::default());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<ImplementsDefault>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:27:42
|
|
|
|
|
LL | let _impl3: Box<ImplementsDefault> = Box::new(Default::default());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:29:28
|
|
|
|
|
LL | let _in_macro = outer!(Box::new(String::new()));
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<String>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:30:34
|
|
|
|
|
LL | let _string_default = outer!(Box::new(String::from("")));
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<String>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:31:46
|
|
|
|
|
LL | let _vec2: Box<Vec<ImplementsDefault>> = Box::new(vec![]);
|
|
| ^^^^^^^^^^^^^^^^ help: try: `Box::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:32:33
|
|
|
|
|
LL | let _vec3: Box<Vec<bool>> = Box::new(Vec::from([]));
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:33:25
|
|
|
|
|
LL | let _vec4: Box<_> = Box::new(Vec::from([false; 0]));
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<Vec<bool>>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:35:16
|
|
|
|
|
LL | call_ty_fn(Box::new(u8::default()));
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:47:5
|
|
|
|
|
LL | Box::new(bool::default())
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<bool>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:64:28
|
|
|
|
|
LL | let _: Box<dyn Read> = Box::new(ImplementsDefault::default());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<ImplementsDefault>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:73:17
|
|
|
|
|
LL | let _ = Box::new(WeirdPathed::default());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<WeirdPathed>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:85:18
|
|
|
|
|
LL | Some(Box::new(Foo::default()))
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<Foo>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:119:18
|
|
|
|
|
LL | let _b = Box::new(outer::Inner::default());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<outer::Inner>::default()`
|
|
|
|
error: `Box::new(_)` of default value
|
|
--> tests/ui/box_default.rs:120:18
|
|
|
|
|
LL | let _b = Box::new(std::collections::HashSet::<i32>::new());
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `Box::<std::collections::HashSet::<i32>>::default()`
|
|
|
|
error: aborting due to 18 previous errors
|
|
|