2023-05-05 17:45:49 +02:00
|
|
|
//@run-rustfix
|
|
|
|
|
|
|
|
#![allow(unused)]
|
|
|
|
#![warn(clippy::default_constructed_unit_structs)]
|
|
|
|
use std::marker::PhantomData;
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
struct UnitStruct;
|
|
|
|
|
|
|
|
impl UnitStruct {
|
|
|
|
fn new() -> Self {
|
|
|
|
//should lint
|
|
|
|
Self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
struct TupleStruct(usize);
|
|
|
|
|
|
|
|
impl TupleStruct {
|
|
|
|
fn new() -> Self {
|
|
|
|
// should not lint
|
|
|
|
Self(Default::default())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// no lint for derived impl
|
|
|
|
#[derive(Default)]
|
|
|
|
struct NormalStruct {
|
|
|
|
inner: PhantomData<usize>,
|
|
|
|
}
|
|
|
|
|
|
|
|
struct NonDefaultStruct;
|
|
|
|
|
|
|
|
impl NonDefaultStruct {
|
|
|
|
fn default() -> Self {
|
|
|
|
Self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
enum SomeEnum {
|
|
|
|
#[default]
|
|
|
|
Unit,
|
|
|
|
Tuple(UnitStruct),
|
|
|
|
Struct {
|
|
|
|
inner: usize,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
impl NormalStruct {
|
|
|
|
fn new() -> Self {
|
|
|
|
// should lint
|
|
|
|
Self {
|
|
|
|
inner: PhantomData,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn new2() -> Self {
|
|
|
|
// should not lint
|
|
|
|
Self {
|
|
|
|
inner: Default::default(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
struct GenericStruct<T> {
|
|
|
|
t: T,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T: Default> GenericStruct<T> {
|
|
|
|
fn new() -> Self {
|
|
|
|
// should not lint
|
|
|
|
Self { t: T::default() }
|
|
|
|
}
|
|
|
|
|
|
|
|
fn new2() -> Self {
|
|
|
|
// should not lint
|
|
|
|
Self { t: Default::default() }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct FakeDefault;
|
|
|
|
impl FakeDefault {
|
|
|
|
fn default() -> Self {
|
|
|
|
Self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Default for FakeDefault {
|
|
|
|
fn default() -> Self {
|
|
|
|
Self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
struct EmptyStruct {}
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
#[non_exhaustive]
|
|
|
|
struct NonExhaustiveStruct;
|
|
|
|
|
2023-06-02 11:41:57 +02:00
|
|
|
mod issue_10755 {
|
|
|
|
struct Sqlite {}
|
|
|
|
|
|
|
|
trait HasArguments<'q> {
|
|
|
|
type Arguments;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'q> HasArguments<'q> for Sqlite {
|
|
|
|
type Arguments = std::marker::PhantomData<&'q ()>;
|
|
|
|
}
|
|
|
|
|
|
|
|
type SqliteArguments<'q> = <Sqlite as HasArguments<'q>>::Arguments;
|
|
|
|
|
|
|
|
fn foo() {
|
|
|
|
// should not lint
|
|
|
|
// type alias cannot be used as a constructor
|
|
|
|
let _ = <Sqlite as HasArguments>::Arguments::default();
|
|
|
|
|
|
|
|
let _ = SqliteArguments::default();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-05-05 17:45:49 +02:00
|
|
|
fn main() {
|
|
|
|
// should lint
|
|
|
|
let _ = PhantomData::<usize>;
|
|
|
|
let _: PhantomData<i32> = PhantomData;
|
2023-05-20 15:39:26 +02:00
|
|
|
let _: PhantomData<i32> = std::marker::PhantomData;
|
2023-05-05 17:45:49 +02:00
|
|
|
let _ = UnitStruct;
|
|
|
|
|
|
|
|
// should not lint
|
|
|
|
let _ = TupleStruct::default();
|
|
|
|
let _ = NormalStruct::default();
|
|
|
|
let _ = NonExhaustiveStruct::default();
|
|
|
|
let _ = SomeEnum::default();
|
|
|
|
let _ = NonDefaultStruct::default();
|
|
|
|
let _ = EmptyStruct::default();
|
|
|
|
let _ = FakeDefault::default();
|
|
|
|
let _ = <FakeDefault as Default>::default();
|
2023-05-20 15:39:26 +02:00
|
|
|
|
|
|
|
macro_rules! in_macro {
|
|
|
|
($i:ident) => {{
|
|
|
|
let _ = UnitStruct::default();
|
|
|
|
let _ = $i::default();
|
|
|
|
}};
|
|
|
|
}
|
|
|
|
|
|
|
|
in_macro!(UnitStruct);
|
|
|
|
|
|
|
|
macro_rules! struct_from_macro {
|
|
|
|
() => {
|
|
|
|
UnitStruct
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
let _ = <struct_from_macro!()>::default();
|
2023-05-05 17:45:49 +02:00
|
|
|
}
|