mirror of
https://github.com/rust-lang/rust.git
synced 2024-12-25 06:56:50 +00:00
1c3424bfc1
I attempted to do this in a manner that preserved the line numbers to reduce the review effort on the resulting diff, but we still have to deal with the ramifications of how a future-incompat lint behaves compared to a hard-error (in terms of its impact on the diagnostic output).
381 lines
18 KiB
Plaintext
381 lines
18 KiB
Plaintext
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:18:1
|
|
|
|
|
LL | const MUH: Meh = Meh {
|
|
| ^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
note: the lint level is defined here
|
|
--> $DIR/mutable_references_err.rs:5:9
|
|
|
|
|
LL | #![deny(const_eval_mutable_ptr_in_final_value)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error[E0080]: it is undefined behavior to use this value
|
|
--> $DIR/mutable_references_err.rs:18:1
|
|
|
|
|
LL | const MUH: Meh = Meh {
|
|
| ^^^^^^^^^^^^^^ constructing invalid value at .x.<deref>: encountered `UnsafeCell` in read-only memory
|
|
|
|
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
|
|
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
|
|
HEX_DUMP
|
|
}
|
|
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:31:1
|
|
|
|
|
LL | const SNEAKY: &dyn Sync = &Synced { x: UnsafeCell::new(42) };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
|
|
error[E0080]: it is undefined behavior to use this value
|
|
--> $DIR/mutable_references_err.rs:31:1
|
|
|
|
|
LL | const SNEAKY: &dyn Sync = &Synced { x: UnsafeCell::new(42) };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value at .<deref>.<dyn-downcast>.x: encountered `UnsafeCell` in read-only memory
|
|
|
|
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
|
|
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
|
|
HEX_DUMP
|
|
}
|
|
|
|
error[E0080]: it is undefined behavior to use this value
|
|
--> $DIR/mutable_references_err.rs:38:1
|
|
|
|
|
LL | const SUBTLE: &mut i32 = unsafe { &mut FOO };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered reference to mutable memory in `const`
|
|
|
|
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
|
|
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
|
|
HEX_DUMP
|
|
}
|
|
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:42:1
|
|
|
|
|
LL | const BLUNT: &mut i32 = &mut 42;
|
|
| ^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
|
|
error[E0080]: it is undefined behavior to use this value
|
|
--> $DIR/mutable_references_err.rs:42:1
|
|
|
|
|
LL | const BLUNT: &mut i32 = &mut 42;
|
|
| ^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered mutable reference or box pointing to read-only memory
|
|
|
|
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
|
|
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
|
|
HEX_DUMP
|
|
}
|
|
|
|
error[E0080]: it is undefined behavior to use this value
|
|
--> $DIR/mutable_references_err.rs:49:1
|
|
|
|
|
LL | static mut MUT_TO_READONLY: &mut i32 = unsafe { &mut *(&READONLY as *const _ as *mut _) };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered mutable reference or box pointing to read-only memory
|
|
|
|
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
|
|
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
|
|
HEX_DUMP
|
|
}
|
|
|
|
error[E0080]: it is undefined behavior to use this value
|
|
--> $DIR/mutable_references_err.rs:56:1
|
|
|
|
|
LL | const POINTS_TO_MUTABLE1: &i32 = unsafe { &MUTABLE };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered reference to mutable memory in `const`
|
|
|
|
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
|
|
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
|
|
HEX_DUMP
|
|
}
|
|
|
|
note: erroneous constant encountered
|
|
--> $DIR/mutable_references_err.rs:58:34
|
|
|
|
|
LL | const READS_FROM_MUTABLE: i32 = *POINTS_TO_MUTABLE1;
|
|
| ^^^^^^^^^^^^^^^^^^
|
|
|
|
error[E0080]: evaluation of constant value failed
|
|
--> $DIR/mutable_references_err.rs:60:43
|
|
|
|
|
LL | const POINTS_TO_MUTABLE2: &i32 = unsafe { &*MUTABLE_REF };
|
|
| ^^^^^^^^^^^^^ constant accesses mutable global memory
|
|
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:64:1
|
|
|
|
|
LL | const POINTS_TO_MUTABLE_INNER: *const i32 = &mut 42 as *mut _ as *const _;
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:68:1
|
|
|
|
|
LL | const POINTS_TO_MUTABLE_INNER2: *const i32 = &mut 42 as *const _;
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:72:1
|
|
|
|
|
LL | const INTERIOR_MUTABLE_BEHIND_RAW: *mut i32 = &UnsafeCell::new(42) as *const _ as *mut _;
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:85:1
|
|
|
|
|
LL | const RAW_SYNC: SyncPtr<AtomicI32> = SyncPtr { x: &AtomicI32::new(42) };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:89:1
|
|
|
|
|
LL | const RAW_MUT_CAST: SyncPtr<i32> = SyncPtr { x: &mut 42 as *mut _ as *const _ };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:93:1
|
|
|
|
|
LL | const RAW_MUT_COERCE: SyncPtr<i32> = SyncPtr { x: &mut 0 };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
|
|
warning: skipping const checks
|
|
|
|
|
help: skipping check that does not even have a feature gate
|
|
--> $DIR/mutable_references_err.rs:22:8
|
|
|
|
|
LL | x: &UnsafeCell::new(42),
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
help: skipping check that does not even have a feature gate
|
|
--> $DIR/mutable_references_err.rs:31:27
|
|
|
|
|
LL | const SNEAKY: &dyn Sync = &Synced { x: UnsafeCell::new(42) };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
help: skipping check for `const_refs_to_static` feature
|
|
--> $DIR/mutable_references_err.rs:38:40
|
|
|
|
|
LL | const SUBTLE: &mut i32 = unsafe { &mut FOO };
|
|
| ^^^
|
|
help: skipping check for `const_mut_refs` feature
|
|
--> $DIR/mutable_references_err.rs:38:35
|
|
|
|
|
LL | const SUBTLE: &mut i32 = unsafe { &mut FOO };
|
|
| ^^^^^^^^
|
|
help: skipping check that does not even have a feature gate
|
|
--> $DIR/mutable_references_err.rs:42:25
|
|
|
|
|
LL | const BLUNT: &mut i32 = &mut 42;
|
|
| ^^^^^^^
|
|
help: skipping check for `const_mut_refs` feature
|
|
--> $DIR/mutable_references_err.rs:49:49
|
|
|
|
|
LL | static mut MUT_TO_READONLY: &mut i32 = unsafe { &mut *(&READONLY as *const _ as *mut _) };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
help: skipping check for `const_mut_refs` feature
|
|
--> $DIR/mutable_references_err.rs:49:49
|
|
|
|
|
LL | static mut MUT_TO_READONLY: &mut i32 = unsafe { &mut *(&READONLY as *const _ as *mut _) };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
help: skipping check for `const_refs_to_static` feature
|
|
--> $DIR/mutable_references_err.rs:56:44
|
|
|
|
|
LL | const POINTS_TO_MUTABLE1: &i32 = unsafe { &MUTABLE };
|
|
| ^^^^^^^
|
|
help: skipping check for `const_refs_to_static` feature
|
|
--> $DIR/mutable_references_err.rs:60:45
|
|
|
|
|
LL | const POINTS_TO_MUTABLE2: &i32 = unsafe { &*MUTABLE_REF };
|
|
| ^^^^^^^^^^^
|
|
help: skipping check that does not even have a feature gate
|
|
--> $DIR/mutable_references_err.rs:64:45
|
|
|
|
|
LL | const POINTS_TO_MUTABLE_INNER: *const i32 = &mut 42 as *mut _ as *const _;
|
|
| ^^^^^^^
|
|
help: skipping check that does not even have a feature gate
|
|
--> $DIR/mutable_references_err.rs:68:46
|
|
|
|
|
LL | const POINTS_TO_MUTABLE_INNER2: *const i32 = &mut 42 as *const _;
|
|
| ^^^^^^^
|
|
help: skipping check that does not even have a feature gate
|
|
--> $DIR/mutable_references_err.rs:72:47
|
|
|
|
|
LL | const INTERIOR_MUTABLE_BEHIND_RAW: *mut i32 = &UnsafeCell::new(42) as *const _ as *mut _;
|
|
| ^^^^^^^^^^^^^^^^^^^^
|
|
help: skipping check that does not even have a feature gate
|
|
--> $DIR/mutable_references_err.rs:85:51
|
|
|
|
|
LL | const RAW_SYNC: SyncPtr<AtomicI32> = SyncPtr { x: &AtomicI32::new(42) };
|
|
| ^^^^^^^^^^^^^^^^^^^
|
|
help: skipping check that does not even have a feature gate
|
|
--> $DIR/mutable_references_err.rs:89:49
|
|
|
|
|
LL | const RAW_MUT_CAST: SyncPtr<i32> = SyncPtr { x: &mut 42 as *mut _ as *const _ };
|
|
| ^^^^^^^
|
|
help: skipping check that does not even have a feature gate
|
|
--> $DIR/mutable_references_err.rs:93:51
|
|
|
|
|
LL | const RAW_MUT_COERCE: SyncPtr<i32> = SyncPtr { x: &mut 0 };
|
|
| ^^^^^^
|
|
|
|
error: aborting due to 16 previous errors; 1 warning emitted
|
|
|
|
For more information about this error, try `rustc --explain E0080`.
|
|
Future incompatibility report: Future breakage diagnostic:
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:18:1
|
|
|
|
|
LL | const MUH: Meh = Meh {
|
|
| ^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
note: the lint level is defined here
|
|
--> $DIR/mutable_references_err.rs:5:9
|
|
|
|
|
LL | #![deny(const_eval_mutable_ptr_in_final_value)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
Future breakage diagnostic:
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:31:1
|
|
|
|
|
LL | const SNEAKY: &dyn Sync = &Synced { x: UnsafeCell::new(42) };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
note: the lint level is defined here
|
|
--> $DIR/mutable_references_err.rs:5:9
|
|
|
|
|
LL | #![deny(const_eval_mutable_ptr_in_final_value)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
Future breakage diagnostic:
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:42:1
|
|
|
|
|
LL | const BLUNT: &mut i32 = &mut 42;
|
|
| ^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
note: the lint level is defined here
|
|
--> $DIR/mutable_references_err.rs:5:9
|
|
|
|
|
LL | #![deny(const_eval_mutable_ptr_in_final_value)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
Future breakage diagnostic:
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:64:1
|
|
|
|
|
LL | const POINTS_TO_MUTABLE_INNER: *const i32 = &mut 42 as *mut _ as *const _;
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
note: the lint level is defined here
|
|
--> $DIR/mutable_references_err.rs:5:9
|
|
|
|
|
LL | #![deny(const_eval_mutable_ptr_in_final_value)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
Future breakage diagnostic:
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:68:1
|
|
|
|
|
LL | const POINTS_TO_MUTABLE_INNER2: *const i32 = &mut 42 as *const _;
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
note: the lint level is defined here
|
|
--> $DIR/mutable_references_err.rs:5:9
|
|
|
|
|
LL | #![deny(const_eval_mutable_ptr_in_final_value)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
Future breakage diagnostic:
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:72:1
|
|
|
|
|
LL | const INTERIOR_MUTABLE_BEHIND_RAW: *mut i32 = &UnsafeCell::new(42) as *const _ as *mut _;
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
note: the lint level is defined here
|
|
--> $DIR/mutable_references_err.rs:5:9
|
|
|
|
|
LL | #![deny(const_eval_mutable_ptr_in_final_value)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
Future breakage diagnostic:
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:85:1
|
|
|
|
|
LL | const RAW_SYNC: SyncPtr<AtomicI32> = SyncPtr { x: &AtomicI32::new(42) };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
note: the lint level is defined here
|
|
--> $DIR/mutable_references_err.rs:5:9
|
|
|
|
|
LL | #![deny(const_eval_mutable_ptr_in_final_value)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
Future breakage diagnostic:
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:89:1
|
|
|
|
|
LL | const RAW_MUT_CAST: SyncPtr<i32> = SyncPtr { x: &mut 42 as *mut _ as *const _ };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
note: the lint level is defined here
|
|
--> $DIR/mutable_references_err.rs:5:9
|
|
|
|
|
LL | #![deny(const_eval_mutable_ptr_in_final_value)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
Future breakage diagnostic:
|
|
error: encountered mutable pointer in final value of constant
|
|
--> $DIR/mutable_references_err.rs:93:1
|
|
|
|
|
LL | const RAW_MUT_COERCE: SyncPtr<i32> = SyncPtr { x: &mut 0 };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
= warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
|
|
= note: for more information, see issue #122153 <https://github.com/rust-lang/rust/issues/122153>
|
|
note: the lint level is defined here
|
|
--> $DIR/mutable_references_err.rs:5:9
|
|
|
|
|
LL | #![deny(const_eval_mutable_ptr_in_final_value)]
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|