-
Notifications
You must be signed in to change notification settings - Fork 13k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of #128714 - camelid:wf-struct-exprs, r=BoxyUwU
WF-check struct field types at construction site Fixes #126272. Fixes #127299. Rustc of course already WF-checked the field types at the definition site, but for error tainting of consts to work properly, there needs to be an error emitted at the use site. Previously, with no use-site error, we proceeded with CTFE and ran into ICEs since we are running code with type errors. Emitting use-site errors also brings struct-like constructors more in line with fn-like constructors since they already emit use-site errors for WF issues. r? `@BoxyUwU`
- Loading branch information
Showing
17 changed files
with
560 additions
and
56 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
28 changes: 28 additions & 0 deletions
28
tests/ui/const-generics/adt_const_params/unsizing-wfcheck-issue-126272.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
// This ensures we don't ICE in situations like rust-lang/rust#126272. | ||
|
||
#![feature(adt_const_params)] | ||
#![allow(incomplete_features)] | ||
|
||
use std::marker::ConstParamTy; | ||
|
||
#[derive(Debug, PartialEq, Eq, ConstParamTy)] | ||
//~^ ERROR the trait `ConstParamTy_` | ||
//~| ERROR the trait `ConstParamTy_` | ||
struct Foo { | ||
nested: &'static Bar<dyn std::fmt::Debug>, | ||
//~^ ERROR the size for values | ||
//~| ERROR the size for values | ||
//~| ERROR binary operation `==` cannot | ||
//~| ERROR the trait bound `dyn Debug: Eq` | ||
//~| ERROR the size for values | ||
} | ||
|
||
#[derive(Debug, PartialEq, Eq, ConstParamTy)] | ||
struct Bar<T>(T); | ||
|
||
struct Test<const F: Foo>; | ||
|
||
fn main() { | ||
let x: Test<{ Foo { nested: &Bar(4) } }> = Test; | ||
//~^ ERROR the size for values | ||
} |
160 changes: 160 additions & 0 deletions
160
tests/ui/const-generics/adt_const_params/unsizing-wfcheck-issue-126272.stderr
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,160 @@ | ||
error[E0277]: the size for values of type `(dyn Debug + 'static)` cannot be known at compilation time | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:12:13 | ||
| | ||
LL | nested: &'static Bar<dyn std::fmt::Debug>, | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ doesn't have a size known at compile-time | ||
| | ||
= help: the trait `Sized` is not implemented for `(dyn Debug + 'static)` | ||
note: required by an implicit `Sized` bound in `Bar` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:21:12 | ||
| | ||
LL | struct Bar<T>(T); | ||
| ^ required by the implicit `Sized` requirement on this type parameter in `Bar` | ||
help: you could relax the implicit `Sized` bound on `T` if it were used through indirection like `&T` or `Box<T>` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:21:12 | ||
| | ||
LL | struct Bar<T>(T); | ||
| ^ - ...if indirection were used here: `Box<T>` | ||
| | | ||
| this could be changed to `T: ?Sized`... | ||
|
||
error[E0204]: the trait `ConstParamTy_` cannot be implemented for this type | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:8:32 | ||
| | ||
LL | #[derive(Debug, PartialEq, Eq, ConstParamTy)] | ||
| ^^^^^^^^^^^^ | ||
... | ||
LL | nested: &'static Bar<dyn std::fmt::Debug>, | ||
| ----------------------------------------- this field does not implement `ConstParamTy_` | ||
| | ||
= note: this error originates in the derive macro `ConstParamTy` (in Nightly builds, run with -Z macro-backtrace for more info) | ||
|
||
error[E0204]: the trait `ConstParamTy_` cannot be implemented for this type | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:8:32 | ||
| | ||
LL | #[derive(Debug, PartialEq, Eq, ConstParamTy)] | ||
| ^^^^^^^^^^^^ | ||
... | ||
LL | nested: &'static Bar<dyn std::fmt::Debug>, | ||
| ----------------------------------------- this field does not implement `ConstParamTy_` | ||
| | ||
note: the `ConstParamTy_` impl for `&'static Bar<(dyn Debug + 'static)>` requires that `(dyn Debug + 'static): Eq` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:12:13 | ||
| | ||
LL | nested: &'static Bar<dyn std::fmt::Debug>, | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
note: the `ConstParamTy_` impl for `&'static Bar<(dyn Debug + 'static)>` requires that `(dyn Debug + 'static): Sized` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:12:13 | ||
| | ||
LL | nested: &'static Bar<dyn std::fmt::Debug>, | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
note: the `ConstParamTy_` impl for `&'static Bar<(dyn Debug + 'static)>` requires that `(dyn Debug + 'static): UnsizedConstParamTy` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:12:13 | ||
| | ||
LL | nested: &'static Bar<dyn std::fmt::Debug>, | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
= note: this error originates in the derive macro `ConstParamTy` (in Nightly builds, run with -Z macro-backtrace for more info) | ||
|
||
error[E0277]: the size for values of type `(dyn Debug + 'static)` cannot be known at compilation time | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:12:5 | ||
| | ||
LL | #[derive(Debug, PartialEq, Eq, ConstParamTy)] | ||
| ----- in this derive macro expansion | ||
... | ||
LL | nested: &'static Bar<dyn std::fmt::Debug>, | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ doesn't have a size known at compile-time | ||
| | ||
= help: the trait `Sized` is not implemented for `(dyn Debug + 'static)`, which is required by `&&'static Bar<(dyn Debug + 'static)>: Debug` | ||
= help: the trait `Debug` is implemented for `Bar<T>` | ||
note: required for `Bar<(dyn Debug + 'static)>` to implement `Debug` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:20:10 | ||
| | ||
LL | #[derive(Debug, PartialEq, Eq, ConstParamTy)] | ||
| ^^^^^ | ||
LL | struct Bar<T>(T); | ||
| - unsatisfied trait bound introduced in this `derive` macro | ||
= note: 2 redundant requirements hidden | ||
= note: required for `&&'static Bar<(dyn Debug + 'static)>` to implement `Debug` | ||
= note: required for the cast from `&&&'static Bar<(dyn Debug + 'static)>` to `&dyn Debug` | ||
= note: this error originates in the derive macro `Debug` (in Nightly builds, run with -Z macro-backtrace for more info) | ||
|
||
error[E0369]: binary operation `==` cannot be applied to type `&Bar<dyn Debug>` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:12:5 | ||
| | ||
LL | #[derive(Debug, PartialEq, Eq, ConstParamTy)] | ||
| --------- in this derive macro expansion | ||
... | ||
LL | nested: &'static Bar<dyn std::fmt::Debug>, | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
| | ||
= note: this error originates in the derive macro `PartialEq` (in Nightly builds, run with -Z macro-backtrace for more info) | ||
|
||
error[E0277]: the trait bound `dyn Debug: Eq` is not satisfied | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:12:5 | ||
| | ||
LL | #[derive(Debug, PartialEq, Eq, ConstParamTy)] | ||
| -- in this derive macro expansion | ||
... | ||
LL | nested: &'static Bar<dyn std::fmt::Debug>, | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `Eq` is not implemented for `dyn Debug`, which is required by `&'static Bar<dyn Debug>: Eq` | ||
| | ||
= help: the trait `Eq` is implemented for `Bar<T>` | ||
note: required for `Bar<dyn Debug>` to implement `Eq` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:20:28 | ||
| | ||
LL | #[derive(Debug, PartialEq, Eq, ConstParamTy)] | ||
| ^^ unsatisfied trait bound introduced in this `derive` macro | ||
= note: 1 redundant requirement hidden | ||
= note: required for `&'static Bar<dyn Debug>` to implement `Eq` | ||
note: required by a bound in `AssertParamIsEq` | ||
--> $SRC_DIR/core/src/cmp.rs:LL:COL | ||
= note: this error originates in the derive macro `Eq` (in Nightly builds, run with -Z macro-backtrace for more info) | ||
|
||
error[E0277]: the size for values of type `dyn Debug` cannot be known at compilation time | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:12:5 | ||
| | ||
LL | #[derive(Debug, PartialEq, Eq, ConstParamTy)] | ||
| -- in this derive macro expansion | ||
... | ||
LL | nested: &'static Bar<dyn std::fmt::Debug>, | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ doesn't have a size known at compile-time | ||
| | ||
= help: the trait `Sized` is not implemented for `dyn Debug` | ||
note: required by an implicit `Sized` bound in `Bar` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:21:12 | ||
| | ||
LL | struct Bar<T>(T); | ||
| ^ required by the implicit `Sized` requirement on this type parameter in `Bar` | ||
help: you could relax the implicit `Sized` bound on `T` if it were used through indirection like `&T` or `Box<T>` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:21:12 | ||
| | ||
LL | struct Bar<T>(T); | ||
| ^ - ...if indirection were used here: `Box<T>` | ||
| | | ||
| this could be changed to `T: ?Sized`... | ||
= note: this error originates in the derive macro `Eq` (in Nightly builds, run with -Z macro-backtrace for more info) | ||
|
||
error[E0277]: the size for values of type `(dyn Debug + 'static)` cannot be known at compilation time | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:26:33 | ||
| | ||
LL | let x: Test<{ Foo { nested: &Bar(4) } }> = Test; | ||
| ^^^^^^^ doesn't have a size known at compile-time | ||
| | ||
= help: the trait `Sized` is not implemented for `(dyn Debug + 'static)` | ||
note: required by an implicit `Sized` bound in `Bar` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:21:12 | ||
| | ||
LL | struct Bar<T>(T); | ||
| ^ required by the implicit `Sized` requirement on this type parameter in `Bar` | ||
help: you could relax the implicit `Sized` bound on `T` if it were used through indirection like `&T` or `Box<T>` | ||
--> $DIR/unsizing-wfcheck-issue-126272.rs:21:12 | ||
| | ||
LL | struct Bar<T>(T); | ||
| ^ - ...if indirection were used here: `Box<T>` | ||
| | | ||
| this could be changed to `T: ?Sized`... | ||
|
||
error: aborting due to 8 previous errors | ||
|
||
Some errors have detailed explanations: E0204, E0277, E0369. | ||
For more information about an error, try `rustc --explain E0204`. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
// This ensures we don't ICE in situations like rust-lang/rust#127299. | ||
|
||
trait Qux { | ||
fn bar() -> i32; | ||
} | ||
|
||
pub struct Lint { | ||
pub desc: &'static dyn Qux, | ||
//~^ ERROR cannot be made into an object | ||
} | ||
|
||
static FOO: &Lint = &Lint { desc: "desc" }; | ||
//~^ ERROR cannot be shared between threads safely | ||
//~| ERROR cannot be made into an object | ||
//~| ERROR cannot be made into an object | ||
|
||
fn main() {} |
Oops, something went wrong.