1 error: a const item should never be interior mutable
2 --> $DIR/non_copy_const.rs:12:1
4 12 | const ATOMIC: AtomicUsize = AtomicUsize::new(5); //~ ERROR interior mutable
5 | -----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
7 | help: make this a static item: `static`
9 = note: #[deny(clippy::declare_interior_mutable_const)] on by default
11 error: a const item should never be interior mutable
12 --> $DIR/non_copy_const.rs:13:1
14 13 | const CELL: Cell<usize> = Cell::new(6); //~ ERROR interior mutable
15 | -----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
17 | help: make this a static item: `static`
19 error: a const item should never be interior mutable
20 --> $DIR/non_copy_const.rs:14:1
22 14 | const ATOMIC_TUPLE: ([AtomicUsize; 1], Vec<AtomicUsize>, u8) = ([ATOMIC], Vec::new(), 7);
23 | -----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
25 | help: make this a static item: `static`
27 error: a const item should never be interior mutable
28 --> $DIR/non_copy_const.rs:18:42
30 18 | ($name:ident: $ty:ty = $e:expr) => { const $name: $ty = $e; };
31 | ^^^^^^^^^^^^^^^^^^^^^^
33 20 | declare_const!(_ONCE: Once = Once::new()); //~ ERROR interior mutable
34 | ------------------------------------------ in this macro invocation
36 error: a const item should never be interior mutable
37 --> $DIR/non_copy_const.rs:41:5
39 41 | const ATOMIC: AtomicUsize; //~ ERROR interior mutable
40 | ^^^^^^^^^^^^^^^^^^^^^^^^^^
42 error: a const item should never be interior mutable
43 --> $DIR/non_copy_const.rs:45:5
48 help: consider requiring `T` to be `Copy`
49 --> $DIR/non_copy_const.rs:45:18
54 error: a const item should never be interior mutable
55 --> $DIR/non_copy_const.rs:48:5
57 48 | const ASSOC: Self::NonCopyType;
58 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
60 help: consider requiring `<Self as Trait<T>>::NonCopyType` to be `Copy`
61 --> $DIR/non_copy_const.rs:48:18
63 48 | const ASSOC: Self::NonCopyType;
66 error: a const item should never be interior mutable
67 --> $DIR/non_copy_const.rs:52:5
69 52 | const AN_INPUT: T = Self::INPUT;
70 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
72 help: consider requiring `T` to be `Copy`
73 --> $DIR/non_copy_const.rs:52:21
75 52 | const AN_INPUT: T = Self::INPUT;
78 error: a const item should never be interior mutable
79 --> $DIR/non_copy_const.rs:18:42
81 18 | ($name:ident: $ty:ty = $e:expr) => { const $name: $ty = $e; };
82 | ^^^^^^^^^^^^^^^^^^^^^^
84 55 | declare_const!(ANOTHER_INPUT: T = Self::INPUT); //~ ERROR interior mutable
85 | ----------------------------------------------- in this macro invocation
87 error: a const item should never be interior mutable
88 --> $DIR/non_copy_const.rs:61:5
90 61 | const SELF_2: Self;
93 help: consider requiring `Self` to be `Copy`
94 --> $DIR/non_copy_const.rs:61:19
96 61 | const SELF_2: Self;
99 error: a const item should never be interior mutable
100 --> $DIR/non_copy_const.rs:82:5
102 82 | const ASSOC_3: AtomicUsize = AtomicUsize::new(14); //~ ERROR interior mutable
103 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
105 error: a const item should never be interior mutable
106 --> $DIR/non_copy_const.rs:85:5
108 85 | const U_SELF: U = U::SELF_2;
109 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
111 help: consider requiring `U` to be `Copy`
112 --> $DIR/non_copy_const.rs:85:19
114 85 | const U_SELF: U = U::SELF_2;
117 error: a const item should never be interior mutable
118 --> $DIR/non_copy_const.rs:88:5
120 88 | const T_ASSOC: T::NonCopyType = T::ASSOC;
121 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
123 help: consider requiring `<T as Trait<u32>>::NonCopyType` to be `Copy`
124 --> $DIR/non_copy_const.rs:88:20
126 88 | const T_ASSOC: T::NonCopyType = T::ASSOC;
129 error: a const item with interior mutability should not be borrowed
130 --> $DIR/non_copy_const.rs:95:5
132 95 | ATOMIC.store(1, Ordering::SeqCst); //~ ERROR interior mutability
135 = note: #[deny(clippy::borrow_interior_mutable_const)] on by default
136 = help: assign this const to a local or static variable, and use the variable here
138 error: a const item with interior mutability should not be borrowed
139 --> $DIR/non_copy_const.rs:96:16
141 96 | assert_eq!(ATOMIC.load(Ordering::SeqCst), 5); //~ ERROR interior mutability
144 = help: assign this const to a local or static variable, and use the variable here
146 error: a const item with interior mutability should not be borrowed
147 --> $DIR/non_copy_const.rs:98:5
149 98 | ATOMIC_USIZE_INIT.store(2, Ordering::SeqCst); //~ ERROR interior mutability
152 = help: assign this const to a local or static variable, and use the variable here
154 error: a const item with interior mutability should not be borrowed
155 --> $DIR/non_copy_const.rs:99:16
157 99 | assert_eq!(ATOMIC_USIZE_INIT.load(Ordering::SeqCst), 0); //~ ERROR interior mutability
160 = help: assign this const to a local or static variable, and use the variable here
162 error: a const item with interior mutability should not be borrowed
163 --> $DIR/non_copy_const.rs:102:22
165 102 | let _once_ref = &ONCE_INIT; //~ ERROR interior mutability
168 = help: assign this const to a local or static variable, and use the variable here
170 error: a const item with interior mutability should not be borrowed
171 --> $DIR/non_copy_const.rs:103:25
173 103 | let _once_ref_2 = &&ONCE_INIT; //~ ERROR interior mutability
176 = help: assign this const to a local or static variable, and use the variable here
178 error: a const item with interior mutability should not be borrowed
179 --> $DIR/non_copy_const.rs:104:27
181 104 | let _once_ref_4 = &&&&ONCE_INIT; //~ ERROR interior mutability
184 = help: assign this const to a local or static variable, and use the variable here
186 error: a const item with interior mutability should not be borrowed
187 --> $DIR/non_copy_const.rs:105:26
189 105 | let _once_mut = &mut ONCE_INIT; //~ ERROR interior mutability
192 = help: assign this const to a local or static variable, and use the variable here
194 error: a const item with interior mutability should not be borrowed
195 --> $DIR/non_copy_const.rs:116:14
197 116 | let _ = &ATOMIC_TUPLE; //~ ERROR interior mutability
200 = help: assign this const to a local or static variable, and use the variable here
202 error: a const item with interior mutability should not be borrowed
203 --> $DIR/non_copy_const.rs:117:14
205 117 | let _ = &ATOMIC_TUPLE.0; //~ ERROR interior mutability
208 = help: assign this const to a local or static variable, and use the variable here
210 error: a const item with interior mutability should not be borrowed
211 --> $DIR/non_copy_const.rs:118:19
213 118 | let _ = &(&&&&ATOMIC_TUPLE).0; //~ ERROR interior mutability
216 = help: assign this const to a local or static variable, and use the variable here
218 error: a const item with interior mutability should not be borrowed
219 --> $DIR/non_copy_const.rs:119:14
221 119 | let _ = &ATOMIC_TUPLE.0[0]; //~ ERROR interior mutability
224 = help: assign this const to a local or static variable, and use the variable here
226 error: a const item with interior mutability should not be borrowed
227 --> $DIR/non_copy_const.rs:120:13
229 120 | let _ = ATOMIC_TUPLE.0[0].load(Ordering::SeqCst); //~ ERROR interior mutability
232 = help: assign this const to a local or static variable, and use the variable here
234 error: a const item with interior mutability should not be borrowed
235 --> $DIR/non_copy_const.rs:126:13
237 126 | let _ = ATOMIC_TUPLE.0[0]; //~ ERROR interior mutability
240 = help: assign this const to a local or static variable, and use the variable here
242 error: a const item with interior mutability should not be borrowed
243 --> $DIR/non_copy_const.rs:131:5
245 131 | CELL.set(2); //~ ERROR interior mutability
248 = help: assign this const to a local or static variable, and use the variable here
250 error: a const item with interior mutability should not be borrowed
251 --> $DIR/non_copy_const.rs:132:16
253 132 | assert_eq!(CELL.get(), 6); //~ ERROR interior mutability
256 = help: assign this const to a local or static variable, and use the variable here
258 error: a const item with interior mutability should not be borrowed
259 --> $DIR/non_copy_const.rs:145:5
261 145 | u64::ATOMIC.store(5, Ordering::SeqCst); //~ ERROR interior mutability
264 = help: assign this const to a local or static variable, and use the variable here
266 error: a const item with interior mutability should not be borrowed
267 --> $DIR/non_copy_const.rs:146:16
269 146 | assert_eq!(u64::ATOMIC.load(Ordering::SeqCst), 9); //~ ERROR interior mutability
272 = help: assign this const to a local or static variable, and use the variable here
274 error: aborting due to 31 previous errors