//@revisions: 32bit 64bit //@aux-build:proc_macros.rs //@no-rustfix //@[32bit]ignore-bitwidth: 64 //@[64bit]ignore-bitwidth: 32 #![allow(dead_code)] #![allow(unused_variables)] #![warn(clippy::large_enum_variant)] extern crate proc_macros; use proc_macros::external; enum LargeEnum { //~^ large_enum_variant A(i32), B([i32; 8000]), } enum GenericEnumOk { A(i32), B([T; 8000]), } enum GenericEnum2 { A(i32), B([i32; 8000]), C(T, [i32; 8000]), } trait SomeTrait { type Item; } enum LargeEnumGeneric { Var(A::Item), } enum LargeEnum2 { //~^ large_enum_variant VariantOk(i32, u32), ContainingLargeEnum(LargeEnum), } enum LargeEnum3 { //~^ large_enum_variant ContainingMoreThanOneField(i32, [i32; 8000], [i32; 9500]), VoidVariant, StructLikeLittle { x: i32, y: i32 }, } enum LargeEnum4 { //~^ large_enum_variant VariantOk(i32, u32), StructLikeLarge { x: [i32; 8000], y: i32 }, } enum LargeEnum5 { //~^ large_enum_variant VariantOk(i32, u32), StructLikeLarge2 { x: [i32; 8000] }, } enum LargeEnumOk { LargeA([i32; 8000]), LargeB([i32; 8001]), } enum LargeEnum6 { A, B([u8; 255]), C([u8; 200]), } enum LargeEnum7 { //~^ large_enum_variant A, B([u8; 1255]), C([u8; 200]), } enum LargeEnum8 { //~^ large_enum_variant VariantOk(i32, u32), ContainingMoreThanOneField([i32; 8000], [i32; 2], [i32; 9500], [i32; 30]), } enum LargeEnum9 { //~^ large_enum_variant A(Struct<()>), B(Struct2), } enum LargeEnumOk2 { //~^ large_enum_variant A(T), B(Struct2), } enum LargeEnumOk3 { //~^ large_enum_variant A(Struct), B(Struct2), } struct Struct { a: i32, t: T, } struct Struct2 { a: [i32; 8000], } #[derive(Copy, Clone)] enum CopyableLargeEnum { //~^ large_enum_variant A(bool), B([u64; 8000]), } enum ManuallyCopyLargeEnum { //~^ large_enum_variant A(bool), B([u64; 8000]), } impl Clone for ManuallyCopyLargeEnum { fn clone(&self) -> Self { *self } } impl Copy for ManuallyCopyLargeEnum {} enum SomeGenericPossiblyCopyEnum { //~^ large_enum_variant A(bool, std::marker::PhantomData), B([u64; 4000]), } impl Clone for SomeGenericPossiblyCopyEnum { fn clone(&self) -> Self { *self } } impl Copy for SomeGenericPossiblyCopyEnum {} enum LargeEnumWithGenerics { //~^ large_enum_variant Small, Large((T, [u8; 512])), } struct Foo { foo: T, } enum WithGenerics { //~^ large_enum_variant Large([Foo; 64]), Small(u8), } enum PossiblyLargeEnumWithConst { SmallBuffer([u8; 4]), MightyBuffer([u16; U]), } enum LargeEnumOfConst { //~^ large_enum_variant Ok, Error(PossiblyLargeEnumWithConst<256>), } enum WithRecursion { //~^ large_enum_variant Large([u64; 64]), Recursive(Box), } enum WithRecursionAndGenerics { Large([T; 64]), Recursive(Box>), } enum LargeEnumWithGenericsAndRecursive { //~^ large_enum_variant Ok(), Error(WithRecursionAndGenerics), } fn main() { external!( enum LargeEnumInMacro { A(i32), B([i32; 8000]), } ); } mod issue11915 { use std::sync::atomic::AtomicPtr; pub struct Bytes { ptr: *const u8, len: usize, // inlined "trait object" data: AtomicPtr<()>, vtable: &'static Vtable, } pub(crate) struct Vtable { /// fn(data, ptr, len) pub clone: unsafe fn(&AtomicPtr<()>, *const u8, usize) -> Bytes, /// fn(data, ptr, len) /// /// takes `Bytes` to value pub to_vec: unsafe fn(&AtomicPtr<()>, *const u8, usize) -> Vec, /// fn(data, ptr, len) pub drop: unsafe fn(&mut AtomicPtr<()>, *const u8, usize), } enum NoWarnings { //~[64bit]^ large_enum_variant BigBoi(PublishWithBytes), _SmallBoi(u8), } enum MakesClippyAngry { //~[64bit]^ large_enum_variant BigBoi(PublishWithVec), _SmallBoi(u8), } struct PublishWithBytes { _dup: bool, _retain: bool, _topic: Bytes, __topic: Bytes, ___topic: Bytes, ____topic: Bytes, _pkid: u16, _payload: Bytes, __payload: Bytes, ___payload: Bytes, ____payload: Bytes, _____payload: Bytes, } struct PublishWithVec { _dup: bool, _retain: bool, _topic: Vec, __topic: Vec, ___topic: Vec, ____topic: Vec, _pkid: u16, _payload: Vec, __payload: Vec, ___payload: Vec, ____payload: Vec, _____payload: Vec, } }