2020-02-15 12:13:20 +00:00
|
|
|
error: the type `&T` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:54:32
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
2019-08-07 08:42:50 +02:00
|
|
|
LL | let _val: &'static T = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
2022-09-18 19:55:36 +04:00
|
|
|
= note: references must be non-null
|
2020-01-22 23:57:38 +00:00
|
|
|
note: the lint level is defined here
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:6:9
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
|
|
|
LL | #![deny(invalid_value)]
|
|
|
|
| ^^^^^^^^^^^^^
|
2019-08-07 08:42:50 +02:00
|
|
|
|
2020-02-15 12:13:20 +00:00
|
|
|
error: the type `&T` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:55:32
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: &'static T = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: references must be non-null
|
2019-08-07 08:42:50 +02:00
|
|
|
|
2020-02-15 12:13:20 +00:00
|
|
|
error: the type `Wrap<&T>` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:57:38
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Wrap<&'static T> = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2023-07-21 22:35:57 -07:00
|
|
|
= note: `Wrap<&T>` must be non-null
|
|
|
|
note: because references must be non-null (in this struct field)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:17:18
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
|
|
|
LL | struct Wrap<T> { wrapped: T }
|
|
|
|
| ^^^^^^^^^^
|
2019-08-07 08:42:50 +02:00
|
|
|
|
2020-02-15 12:13:20 +00:00
|
|
|
error: the type `Wrap<&T>` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:58:38
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Wrap<&'static T> = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
2023-07-21 22:35:57 -07:00
|
|
|
= note: `Wrap<&T>` must be non-null
|
|
|
|
note: because references must be non-null (in this struct field)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:17:18
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2019-08-12 09:24:13 +02:00
|
|
|
LL | struct Wrap<T> { wrapped: T }
|
|
|
|
| ^^^^^^^^^^
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
error: the type `!` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:65:23
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: ! = mem::zeroed();
|
2023-02-13 15:38:23 +01:00
|
|
|
| ^^^^^^^^^^^^^ this code causes undefined behavior when executed
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: the `!` type has no valid value
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
|
|
error: the type `!` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:66:23
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
|
|
|
LL | let _val: ! = mem::uninitialized();
|
2023-02-13 15:38:23 +01:00
|
|
|
| ^^^^^^^^^^^^^^^^^^^^ this code causes undefined behavior when executed
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: the `!` type has no valid value
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
error: the type `(i32, !)` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:68:30
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: (i32, !) = mem::zeroed();
|
2023-02-13 15:38:23 +01:00
|
|
|
| ^^^^^^^^^^^^^ this code causes undefined behavior when executed
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: the `!` type has no valid value
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
error: the type `(i32, !)` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:69:30
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: (i32, !) = mem::uninitialized();
|
2023-02-13 15:38:23 +01:00
|
|
|
| ^^^^^^^^^^^^^^^^^^^^ this code causes undefined behavior when executed
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2022-11-07 10:52:48 +00:00
|
|
|
= note: integers must be initialized
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
error: the type `Void` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:71:26
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Void = mem::zeroed();
|
2023-02-13 15:38:23 +01:00
|
|
|
| ^^^^^^^^^^^^^ this code causes undefined behavior when executed
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2022-09-25 22:56:01 +02:00
|
|
|
note: enums with no inhabited variants have no valid value
|
|
|
|
--> $DIR/invalid_value.rs:12:1
|
|
|
|
|
|
|
|
|
LL | enum Void {}
|
|
|
|
| ^^^^^^^^^
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
error: the type `Void` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:72:26
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Void = mem::uninitialized();
|
2023-02-13 15:38:23 +01:00
|
|
|
| ^^^^^^^^^^^^^^^^^^^^ this code causes undefined behavior when executed
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2022-09-25 22:56:01 +02:00
|
|
|
note: enums with no inhabited variants have no valid value
|
|
|
|
--> $DIR/invalid_value.rs:12:1
|
|
|
|
|
|
|
|
|
LL | enum Void {}
|
|
|
|
| ^^^^^^^^^
|
2019-08-06 23:11:52 +02:00
|
|
|
|
2020-02-15 12:13:20 +00:00
|
|
|
error: the type `&i32` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:74:34
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
|
|
|
LL | let _val: &'static i32 = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: references must be non-null
|
2019-08-06 23:11:52 +02:00
|
|
|
|
2020-02-15 12:13:20 +00:00
|
|
|
error: the type `&i32` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:75:34
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
|
|
|
LL | let _val: &'static i32 = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: references must be non-null
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
error: the type `Ref` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:77:25
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Ref = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
2022-11-03 09:20:27 +00:00
|
|
|
= note: `Ref` must be non-null
|
2022-11-07 10:48:40 +00:00
|
|
|
note: because references must be non-null (in this struct field)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:14:12
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2019-08-12 09:24:13 +02:00
|
|
|
LL | struct Ref(&'static i32);
|
|
|
|
| ^^^^^^^^^^^^
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
error: the type `Ref` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:78:25
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Ref = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2022-11-03 09:20:27 +00:00
|
|
|
= note: `Ref` must be non-null
|
2022-11-07 10:48:40 +00:00
|
|
|
note: because references must be non-null (in this struct field)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:14:12
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
|
|
|
LL | struct Ref(&'static i32);
|
|
|
|
| ^^^^^^^^^^^^
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
|
|
error: the type `fn()` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:80:26
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
|
|
|
LL | let _val: fn() = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: function pointers must be non-null
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
|
|
error: the type `fn()` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:81:26
|
2019-08-06 23:11:52 +02:00
|
|
|
|
|
|
|
|
LL | let _val: fn() = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: function pointers must be non-null
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
error: the type `Wrap<fn()>` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:83:32
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Wrap<fn()> = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
2022-11-03 09:20:27 +00:00
|
|
|
= note: `Wrap<fn()>` must be non-null
|
2022-11-07 10:48:40 +00:00
|
|
|
note: because function pointers must be non-null (in this struct field)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:17:18
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2019-08-12 09:24:13 +02:00
|
|
|
LL | struct Wrap<T> { wrapped: T }
|
|
|
|
| ^^^^^^^^^^
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
error: the type `Wrap<fn()>` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:84:32
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Wrap<fn()> = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
2019-08-12 09:24:13 +02:00
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
2022-11-03 09:20:27 +00:00
|
|
|
= note: `Wrap<fn()>` must be non-null
|
2022-11-07 10:48:40 +00:00
|
|
|
note: because function pointers must be non-null (in this struct field)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:17:18
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
|
|
|
LL | struct Wrap<T> { wrapped: T }
|
|
|
|
| ^^^^^^^^^^
|
|
|
|
|
|
|
|
error: the type `WrapEnum<fn()>` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:86:36
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
|
|
|
LL | let _val: WrapEnum<fn()> = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
2022-11-03 09:20:27 +00:00
|
|
|
= note: `WrapEnum<fn()>` must be non-null
|
2022-11-07 10:48:40 +00:00
|
|
|
note: because function pointers must be non-null (in this field of the only potentially inhabited enum variant)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:18:28
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
|
|
|
LL | enum WrapEnum<T> { Wrapped(T) }
|
|
|
|
| ^
|
|
|
|
|
|
|
|
error: the type `WrapEnum<fn()>` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:87:36
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
|
|
|
LL | let _val: WrapEnum<fn()> = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
2022-11-03 09:20:27 +00:00
|
|
|
= note: `WrapEnum<fn()>` must be non-null
|
2022-11-07 10:48:40 +00:00
|
|
|
note: because function pointers must be non-null (in this field of the only potentially inhabited enum variant)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:18:28
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
|
|
|
LL | enum WrapEnum<T> { Wrapped(T) }
|
|
|
|
| ^
|
|
|
|
|
|
|
|
error: the type `Wrap<(RefPair, i32)>` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:89:42
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Wrap<(RefPair, i32)> = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
2022-11-03 10:17:50 +00:00
|
|
|
note: `RefPair` must be non-null (in this struct field)
|
2022-11-03 09:10:31 +00:00
|
|
|
--> $DIR/invalid_value.rs:17:18
|
|
|
|
|
|
|
|
|
LL | struct Wrap<T> { wrapped: T }
|
|
|
|
| ^^^^^^^^^^
|
2022-11-07 10:48:40 +00:00
|
|
|
note: because references must be non-null (in this struct field)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:15:16
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
|
|
|
LL | struct RefPair((&'static i32, i32));
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
error: the type `Wrap<(RefPair, i32)>` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:90:42
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Wrap<(RefPair, i32)> = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-12 09:24:13 +02:00
|
|
|
|
|
2022-11-03 10:17:50 +00:00
|
|
|
note: `RefPair` must be non-null (in this struct field)
|
2022-11-03 09:10:31 +00:00
|
|
|
--> $DIR/invalid_value.rs:17:18
|
|
|
|
|
|
|
|
|
LL | struct Wrap<T> { wrapped: T }
|
|
|
|
| ^^^^^^^^^^
|
2022-11-07 10:48:40 +00:00
|
|
|
note: because references must be non-null (in this struct field)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:15:16
|
2019-08-07 08:42:50 +02:00
|
|
|
|
|
2019-08-12 09:24:13 +02:00
|
|
|
LL | struct RefPair((&'static i32, i32));
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^
|
2019-08-06 23:11:52 +02:00
|
|
|
|
2020-09-02 10:40:56 +03:00
|
|
|
error: the type `NonNull<i32>` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:92:34
|
2019-08-17 10:13:47 +02:00
|
|
|
|
|
2019-08-17 22:11:43 +02:00
|
|
|
LL | let _val: NonNull<i32> = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-17 10:13:47 +02:00
|
|
|
|
|
2020-09-03 14:33:55 +03:00
|
|
|
= note: `std::ptr::NonNull<i32>` must be non-null
|
2019-08-17 10:13:47 +02:00
|
|
|
|
2020-09-02 10:40:56 +03:00
|
|
|
error: the type `NonNull<i32>` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:93:34
|
2019-08-17 10:13:47 +02:00
|
|
|
|
|
2019-08-17 22:11:43 +02:00
|
|
|
LL | let _val: NonNull<i32> = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-17 10:13:47 +02:00
|
|
|
|
|
2020-09-03 14:33:55 +03:00
|
|
|
= note: `std::ptr::NonNull<i32>` must be non-null
|
2022-11-07 10:52:48 +00:00
|
|
|
= note: raw pointers must be initialized
|
2019-08-17 10:13:47 +02:00
|
|
|
|
2024-01-20 18:55:53 +01:00
|
|
|
error: the type `(NonZero<u32>, i32)` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:95:39
|
2022-09-20 11:33:16 +02:00
|
|
|
|
|
|
|
|
LL | let _val: (NonZeroU32, i32) = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
2024-01-20 18:55:53 +01:00
|
|
|
= note: `std::num::NonZero<u32>` must be non-null
|
2022-09-20 11:33:16 +02:00
|
|
|
|
2024-01-20 18:55:53 +01:00
|
|
|
error: the type `(NonZero<u32>, i32)` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:96:39
|
2022-09-20 11:33:16 +02:00
|
|
|
|
|
|
|
|
LL | let _val: (NonZeroU32, i32) = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
2024-01-20 18:55:53 +01:00
|
|
|
= note: `std::num::NonZero<u32>` must be non-null
|
2022-11-07 10:52:48 +00:00
|
|
|
= note: integers must be initialized
|
2022-09-20 11:33:16 +02:00
|
|
|
|
2020-09-02 10:40:56 +03:00
|
|
|
error: the type `*const dyn Send` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:98:37
|
2019-11-02 11:56:06 +01:00
|
|
|
|
|
|
|
|
LL | let _val: *const dyn Send = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-11-02 11:56:06 +01:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: the vtable of a wide raw pointer must be non-null
|
2019-11-02 11:56:06 +01:00
|
|
|
|
2020-09-02 10:40:56 +03:00
|
|
|
error: the type `*const dyn Send` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:99:37
|
2019-11-02 11:56:06 +01:00
|
|
|
|
|
|
|
|
LL | let _val: *const dyn Send = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-11-02 11:56:06 +01:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: the vtable of a wide raw pointer must be non-null
|
2019-11-02 11:56:06 +01:00
|
|
|
|
2022-03-27 13:10:34 -04:00
|
|
|
error: the type `[fn(); 2]` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:101:31
|
2022-03-27 13:10:34 -04:00
|
|
|
|
|
|
|
|
LL | let _val: [fn(); 2] = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
|
|
|
= note: function pointers must be non-null
|
|
|
|
|
|
|
|
error: the type `[fn(); 2]` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:102:31
|
2022-03-27 13:10:34 -04:00
|
|
|
|
|
|
|
|
LL | let _val: [fn(); 2] = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
|
|
|
= note: function pointers must be non-null
|
|
|
|
|
2022-09-25 22:56:01 +02:00
|
|
|
error: the type `TwoUninhabited` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:104:36
|
2022-09-25 22:56:01 +02:00
|
|
|
|
|
|
|
|
LL | let _val: TwoUninhabited = mem::zeroed();
|
2023-02-13 15:38:23 +01:00
|
|
|
| ^^^^^^^^^^^^^ this code causes undefined behavior when executed
|
2022-09-25 22:56:01 +02:00
|
|
|
|
|
|
|
|
note: enums with no inhabited variants have no valid value
|
|
|
|
--> $DIR/invalid_value.rs:42:1
|
|
|
|
|
|
|
|
|
LL | enum TwoUninhabited {
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
error: the type `TwoUninhabited` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:105:36
|
2022-09-25 22:56:01 +02:00
|
|
|
|
|
|
|
|
LL | let _val: TwoUninhabited = mem::uninitialized();
|
2023-02-13 15:38:23 +01:00
|
|
|
| ^^^^^^^^^^^^^^^^^^^^ this code causes undefined behavior when executed
|
2022-09-25 22:56:01 +02:00
|
|
|
|
|
|
|
|
note: enums with no inhabited variants have no valid value
|
|
|
|
--> $DIR/invalid_value.rs:42:1
|
|
|
|
|
|
|
|
|
LL | enum TwoUninhabited {
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
error: the type `OneFruitNonZero` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:107:37
|
2022-09-25 22:56:01 +02:00
|
|
|
|
|
|
|
|
LL | let _val: OneFruitNonZero = mem::zeroed();
|
|
|
|
| ^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
2022-11-03 09:20:27 +00:00
|
|
|
= note: `OneFruitNonZero` must be non-null
|
2024-01-20 18:55:53 +01:00
|
|
|
note: because `std::num::NonZero<u32>` must be non-null (in this field of the only potentially inhabited enum variant)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:39:12
|
|
|
|
|
|
|
|
|
LL | Banana(NonZeroU32),
|
|
|
|
| ^^^^^^^^^^
|
|
|
|
|
|
|
|
error: the type `OneFruitNonZero` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:108:37
|
2022-09-25 22:56:01 +02:00
|
|
|
|
|
|
|
|
LL | let _val: OneFruitNonZero = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
2022-11-03 09:20:27 +00:00
|
|
|
= note: `OneFruitNonZero` must be non-null
|
2024-01-20 18:55:53 +01:00
|
|
|
note: because `std::num::NonZero<u32>` must be non-null (in this field of the only potentially inhabited enum variant)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:39:12
|
|
|
|
|
|
|
|
|
LL | Banana(NonZeroU32),
|
|
|
|
| ^^^^^^^^^^
|
2022-11-07 10:52:48 +00:00
|
|
|
= note: integers must be initialized
|
2022-09-25 22:56:01 +02:00
|
|
|
|
2019-08-17 09:39:25 +02:00
|
|
|
error: the type `bool` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:112:26
|
2019-08-17 09:39:25 +02:00
|
|
|
|
|
|
|
|
LL | let _val: bool = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-17 09:39:25 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: booleans must be either `true` or `false`
|
2019-08-17 09:39:25 +02:00
|
|
|
|
|
|
|
error: the type `Wrap<char>` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:115:32
|
2019-08-17 09:39:25 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Wrap<char> = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-17 09:39:25 +02:00
|
|
|
|
|
2022-11-03 09:20:27 +00:00
|
|
|
= note: `Wrap<char>` must be initialized inside its custom valid range
|
2022-11-03 10:17:50 +00:00
|
|
|
note: characters must be a valid Unicode codepoint (in this struct field)
|
2022-09-25 22:56:01 +02:00
|
|
|
--> $DIR/invalid_value.rs:17:18
|
2019-08-17 09:39:25 +02:00
|
|
|
|
|
|
|
|
LL | struct Wrap<T> { wrapped: T }
|
|
|
|
| ^^^^^^^^^^
|
|
|
|
|
2019-08-17 10:13:47 +02:00
|
|
|
error: the type `NonBig` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:118:28
|
2019-08-17 10:13:47 +02:00
|
|
|
|
|
|
|
|
LL | let _val: NonBig = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-17 10:13:47 +02:00
|
|
|
|
|
2020-01-10 14:57:36 +00:00
|
|
|
= note: `NonBig` must be initialized inside its custom valid range
|
2022-11-07 10:52:48 +00:00
|
|
|
note: integers must be initialized (in this struct field)
|
2022-11-03 09:20:27 +00:00
|
|
|
--> $DIR/invalid_value.rs:23:26
|
|
|
|
|
|
|
|
|
LL | pub(crate) struct NonBig(u64);
|
|
|
|
| ^^^
|
2019-08-17 10:13:47 +02:00
|
|
|
|
2020-07-17 15:01:37 +02:00
|
|
|
error: the type `Fruit` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:121:27
|
2020-07-17 15:01:37 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Fruit = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
2022-09-25 22:56:01 +02:00
|
|
|
note: enums with multiple inhabited variants have to be initialized to a variant
|
|
|
|
--> $DIR/invalid_value.rs:26:1
|
2020-07-17 15:01:37 +02:00
|
|
|
|
|
2022-02-13 16:27:59 +01:00
|
|
|
LL | enum Fruit {
|
|
|
|
| ^^^^^^^^^^
|
2020-07-17 15:01:37 +02:00
|
|
|
|
2022-03-27 13:10:34 -04:00
|
|
|
error: the type `[bool; 2]` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:124:31
|
2022-03-27 13:10:34 -04:00
|
|
|
|
|
|
|
|
LL | let _val: [bool; 2] = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
|
|
|
= note: booleans must be either `true` or `false`
|
|
|
|
|
2022-07-04 23:57:41 +01:00
|
|
|
error: the type `i32` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:127:25
|
2022-07-04 23:57:41 +01:00
|
|
|
|
|
|
|
|
LL | let _val: i32 = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
2022-11-07 10:52:48 +00:00
|
|
|
= note: integers must be initialized
|
2022-07-04 23:57:41 +01:00
|
|
|
|
2022-07-05 08:50:42 +01:00
|
|
|
error: the type `f32` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:130:25
|
2022-07-05 08:50:42 +01:00
|
|
|
|
|
|
|
|
LL | let _val: f32 = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
2022-11-07 10:52:48 +00:00
|
|
|
= note: floats must be initialized
|
2022-07-05 08:50:42 +01:00
|
|
|
|
|
|
|
error: the type `*const ()` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:133:31
|
2022-07-05 08:50:42 +01:00
|
|
|
|
|
|
|
|
LL | let _val: *const () = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
2022-11-07 10:52:48 +00:00
|
|
|
= note: raw pointers must be initialized
|
2022-07-05 08:50:42 +01:00
|
|
|
|
|
|
|
error: the type `*const [()]` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:136:33
|
2022-07-05 08:50:42 +01:00
|
|
|
|
|
|
|
|
LL | let _val: *const [()] = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
2022-11-07 10:52:48 +00:00
|
|
|
= note: raw pointers must be initialized
|
2022-07-05 08:50:42 +01:00
|
|
|
|
2022-10-22 15:37:46 +01:00
|
|
|
error: the type `WrapAroundRange` does not permit being left uninitialized
|
|
|
|
--> $DIR/invalid_value.rs:139:37
|
|
|
|
|
|
|
|
|
LL | let _val: WrapAroundRange = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
|
|
|
= note: `WrapAroundRange` must be initialized inside its custom valid range
|
2022-11-07 10:52:48 +00:00
|
|
|
note: integers must be initialized (in this struct field)
|
2022-11-03 09:20:27 +00:00
|
|
|
--> $DIR/invalid_value.rs:49:35
|
|
|
|
|
|
|
|
|
LL | pub(crate) struct WrapAroundRange(u8);
|
|
|
|
| ^^
|
2022-10-22 15:37:46 +01:00
|
|
|
|
2022-09-25 22:56:01 +02:00
|
|
|
error: the type `Result<i32, i32>` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:144:38
|
2022-09-25 22:56:01 +02:00
|
|
|
|
|
|
|
|
LL | let _val: Result<i32, i32> = mem::uninitialized();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
|
|
|
|
|
|
|
|
note: enums with multiple inhabited variants have to be initialized to a variant
|
|
|
|
--> $SRC_DIR/core/src/result.rs:LL:COL
|
|
|
|
|
2020-02-15 12:13:20 +00:00
|
|
|
error: the type `&i32` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:152:34
|
2019-08-17 11:48:30 +02:00
|
|
|
|
|
|
|
|
LL | let _val: &'static i32 = mem::transmute(0usize);
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-17 11:48:30 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: references must be non-null
|
2019-08-17 11:48:30 +02:00
|
|
|
|
2020-02-15 12:13:20 +00:00
|
|
|
error: the type `&[i32]` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:153:36
|
2019-08-17 11:48:30 +02:00
|
|
|
|
|
|
|
|
LL | let _val: &'static [i32] = mem::transmute((0usize, 0usize));
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-17 11:48:30 +02:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: references must be non-null
|
2019-08-17 11:48:30 +02:00
|
|
|
|
2024-01-20 18:55:53 +01:00
|
|
|
error: the type `NonZero<u32>` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:154:32
|
2019-08-17 11:48:30 +02:00
|
|
|
|
|
|
|
|
LL | let _val: NonZeroU32 = mem::transmute(0);
|
|
|
|
| ^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-08-17 11:48:30 +02:00
|
|
|
|
|
2024-01-20 18:55:53 +01:00
|
|
|
= note: `std::num::NonZero<u32>` must be non-null
|
2019-08-17 11:48:30 +02:00
|
|
|
|
2020-09-02 10:40:56 +03:00
|
|
|
error: the type `NonNull<i32>` does not permit zero-initialization
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:157:34
|
2019-11-02 16:12:33 +01:00
|
|
|
|
|
|
|
|
LL | let _val: NonNull<i32> = MaybeUninit::zeroed().assume_init();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-11-02 16:12:33 +01:00
|
|
|
|
|
2020-09-03 14:33:55 +03:00
|
|
|
= note: `std::ptr::NonNull<i32>` must be non-null
|
2019-11-02 16:12:33 +01:00
|
|
|
|
2020-09-02 10:40:56 +03:00
|
|
|
error: the type `NonNull<i32>` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:158:34
|
2019-11-02 16:12:33 +01:00
|
|
|
|
|
|
|
|
LL | let _val: NonNull<i32> = MaybeUninit::uninit().assume_init();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-11-02 16:12:33 +01:00
|
|
|
|
|
2020-09-03 14:33:55 +03:00
|
|
|
= note: `std::ptr::NonNull<i32>` must be non-null
|
2022-11-07 10:52:48 +00:00
|
|
|
= note: raw pointers must be initialized
|
2019-11-02 16:12:33 +01:00
|
|
|
|
|
|
|
error: the type `bool` does not permit being left uninitialized
|
2022-10-22 15:37:46 +01:00
|
|
|
--> $DIR/invalid_value.rs:159:26
|
2019-11-02 16:12:33 +01:00
|
|
|
|
|
|
|
|
LL | let _val: bool = MaybeUninit::uninit().assume_init();
|
|
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
| |
|
|
|
|
| this code causes undefined behavior when executed
|
2019-11-07 10:22:50 +01:00
|
|
|
| help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
|
2019-11-02 16:12:33 +01:00
|
|
|
|
|
2020-01-10 14:13:05 +00:00
|
|
|
= note: booleans must be either `true` or `false`
|
2019-11-02 16:12:33 +01:00
|
|
|
|
2022-10-22 15:37:46 +01:00
|
|
|
error: aborting due to 51 previous errors
|
2019-08-06 23:11:52 +02:00
|
|
|
|