mirror of
https://github.com/rust-lang/rust-clippy
synced 2025-01-06 10:18:48 +00:00
275 lines
9.7 KiB
Text
275 lines
9.7 KiB
Text
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:22:1
|
|
|
|
|
22 | const ATOMIC: AtomicUsize = AtomicUsize::new(5); //~ ERROR interior mutable
|
|
| -----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
| |
|
|
| help: make this a static item: `static`
|
|
|
|
|
= note: #[deny(clippy::declare_interior_mutable_const)] on by default
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:23:1
|
|
|
|
|
23 | const CELL: Cell<usize> = Cell::new(6); //~ ERROR interior mutable
|
|
| -----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
| |
|
|
| help: make this a static item: `static`
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:24:1
|
|
|
|
|
24 | const ATOMIC_TUPLE: ([AtomicUsize; 1], Vec<AtomicUsize>, u8) = ([ATOMIC], Vec::new(), 7);
|
|
| -----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
| |
|
|
| help: make this a static item: `static`
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:28:42
|
|
|
|
|
28 | ($name:ident: $ty:ty = $e:expr) => { const $name: $ty = $e; };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^
|
|
29 | }
|
|
30 | declare_const!(_ONCE: Once = Once::new()); //~ ERROR interior mutable
|
|
| ------------------------------------------ in this macro invocation
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:51:5
|
|
|
|
|
51 | const ATOMIC: AtomicUsize; //~ ERROR interior mutable
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:55:5
|
|
|
|
|
55 | const INPUT: T;
|
|
| ^^^^^^^^^^^^^^^
|
|
|
|
|
help: consider requiring `T` to be `Copy`
|
|
--> $DIR/non_copy_const.rs:55:18
|
|
|
|
|
55 | const INPUT: T;
|
|
| ^
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:58:5
|
|
|
|
|
58 | const ASSOC: Self::NonCopyType;
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
help: consider requiring `<Self as Trait<T>>::NonCopyType` to be `Copy`
|
|
--> $DIR/non_copy_const.rs:58:18
|
|
|
|
|
58 | const ASSOC: Self::NonCopyType;
|
|
| ^^^^^^^^^^^^^^^^^
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:62:5
|
|
|
|
|
62 | const AN_INPUT: T = Self::INPUT;
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
help: consider requiring `T` to be `Copy`
|
|
--> $DIR/non_copy_const.rs:62:21
|
|
|
|
|
62 | const AN_INPUT: T = Self::INPUT;
|
|
| ^
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:28:42
|
|
|
|
|
28 | ($name:ident: $ty:ty = $e:expr) => { const $name: $ty = $e; };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^
|
|
...
|
|
65 | declare_const!(ANOTHER_INPUT: T = Self::INPUT); //~ ERROR interior mutable
|
|
| ----------------------------------------------- in this macro invocation
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:71:5
|
|
|
|
|
71 | const SELF_2: Self;
|
|
| ^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
help: consider requiring `Self` to be `Copy`
|
|
--> $DIR/non_copy_const.rs:71:19
|
|
|
|
|
71 | const SELF_2: Self;
|
|
| ^^^^
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:92:5
|
|
|
|
|
92 | const ASSOC_3: AtomicUsize = AtomicUsize::new(14); //~ ERROR interior mutable
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:95:5
|
|
|
|
|
95 | const U_SELF: U = U::SELF_2;
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
help: consider requiring `U` to be `Copy`
|
|
--> $DIR/non_copy_const.rs:95:19
|
|
|
|
|
95 | const U_SELF: U = U::SELF_2;
|
|
| ^
|
|
|
|
error: a const item should never be interior mutable
|
|
--> $DIR/non_copy_const.rs:98:5
|
|
|
|
|
98 | const T_ASSOC: T::NonCopyType = T::ASSOC;
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
help: consider requiring `<T as Trait<u32>>::NonCopyType` to be `Copy`
|
|
--> $DIR/non_copy_const.rs:98:20
|
|
|
|
|
98 | const T_ASSOC: T::NonCopyType = T::ASSOC;
|
|
| ^^^^^^^^^^^^^^
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:105:5
|
|
|
|
|
105 | ATOMIC.store(1, Ordering::SeqCst); //~ ERROR interior mutability
|
|
| ^^^^^^
|
|
|
|
|
= note: #[deny(clippy::borrow_interior_mutable_const)] on by default
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:106:16
|
|
|
|
|
106 | assert_eq!(ATOMIC.load(Ordering::SeqCst), 5); //~ ERROR interior mutability
|
|
| ^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:108:5
|
|
|
|
|
108 | ATOMIC_USIZE_INIT.store(2, Ordering::SeqCst); //~ ERROR interior mutability
|
|
| ^^^^^^^^^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:109:16
|
|
|
|
|
109 | assert_eq!(ATOMIC_USIZE_INIT.load(Ordering::SeqCst), 0); //~ ERROR interior mutability
|
|
| ^^^^^^^^^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:112:22
|
|
|
|
|
112 | let _once_ref = &ONCE_INIT; //~ ERROR interior mutability
|
|
| ^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:113:25
|
|
|
|
|
113 | let _once_ref_2 = &&ONCE_INIT; //~ ERROR interior mutability
|
|
| ^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:114:27
|
|
|
|
|
114 | let _once_ref_4 = &&&&ONCE_INIT; //~ ERROR interior mutability
|
|
| ^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:115:26
|
|
|
|
|
115 | let _once_mut = &mut ONCE_INIT; //~ ERROR interior mutability
|
|
| ^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:126:14
|
|
|
|
|
126 | let _ = &ATOMIC_TUPLE; //~ ERROR interior mutability
|
|
| ^^^^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:127:14
|
|
|
|
|
127 | let _ = &ATOMIC_TUPLE.0; //~ ERROR interior mutability
|
|
| ^^^^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:128:19
|
|
|
|
|
128 | let _ = &(&&&&ATOMIC_TUPLE).0; //~ ERROR interior mutability
|
|
| ^^^^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:129:14
|
|
|
|
|
129 | let _ = &ATOMIC_TUPLE.0[0]; //~ ERROR interior mutability
|
|
| ^^^^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:130:13
|
|
|
|
|
130 | let _ = ATOMIC_TUPLE.0[0].load(Ordering::SeqCst); //~ ERROR interior mutability
|
|
| ^^^^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:136:13
|
|
|
|
|
136 | let _ = ATOMIC_TUPLE.0[0]; //~ ERROR interior mutability
|
|
| ^^^^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:141:5
|
|
|
|
|
141 | CELL.set(2); //~ ERROR interior mutability
|
|
| ^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:142:16
|
|
|
|
|
142 | assert_eq!(CELL.get(), 6); //~ ERROR interior mutability
|
|
| ^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:155:5
|
|
|
|
|
155 | u64::ATOMIC.store(5, Ordering::SeqCst); //~ ERROR interior mutability
|
|
| ^^^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: a const item with interior mutability should not be borrowed
|
|
--> $DIR/non_copy_const.rs:156:16
|
|
|
|
|
156 | assert_eq!(u64::ATOMIC.load(Ordering::SeqCst), 9); //~ ERROR interior mutability
|
|
| ^^^^^^^^^^^
|
|
|
|
|
= help: assign this const to a local or static variable, and use the variable here
|
|
|
|
error: aborting due to 31 previous errors
|
|
|