-
Notifications
You must be signed in to change notification settings - Fork 12.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix tuple element tys returned from sized_conditions()
Instead of returning the type of only the last element we return the types of all elements. Without it in some situations we were allowing typeck to succeed for tuples which have an unsized element at a non-last position.
- Loading branch information
Showing
11 changed files
with
228 additions
and
52 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 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
16 changes: 16 additions & 0 deletions
16
tests/ui/trait-bounds/ice-unsized-tuple-const-issue-121443.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,16 @@ | ||
// Regression test for #121443 | ||
// Checks that no ICE occurs upon encountering | ||
// a tuple with unsized element that is not | ||
// the last element | ||
|
||
type Fn = dyn FnOnce() -> u8; | ||
|
||
const TEST: Fn = some_fn; | ||
//~^ ERROR cannot find value `some_fn` in this scope | ||
//~| ERROR the size for values of type `(dyn FnOnce() -> u8 + 'static)` cannot be known at compilation time | ||
//~| ERROR the size for values of type `(dyn FnOnce() -> u8 + 'static)` cannot be known at compilation time | ||
const TEST2: (Fn, u8) = (TEST, 0); | ||
//~^ ERROR the size for values of type `(dyn FnOnce() -> u8 + 'static)` cannot be known at compilation time | ||
//~| ERROR the size for values of type `(dyn FnOnce() -> u8 + 'static)` cannot be known at compilation time | ||
|
||
fn main() {} |
46 changes: 46 additions & 0 deletions
46
tests/ui/trait-bounds/ice-unsized-tuple-const-issue-121443.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,46 @@ | ||
error[E0425]: cannot find value `some_fn` in this scope | ||
--> $DIR/ice-unsized-tuple-const-issue-121443.rs:8:18 | ||
| | ||
LL | const TEST: Fn = some_fn; | ||
| ^^^^^^^ not found in this scope | ||
|
||
error[E0277]: the size for values of type `(dyn FnOnce() -> u8 + 'static)` cannot be known at compilation time | ||
--> $DIR/ice-unsized-tuple-const-issue-121443.rs:8:13 | ||
| | ||
LL | const TEST: Fn = some_fn; | ||
| ^^ doesn't have a size known at compile-time | ||
| | ||
= help: the trait `Sized` is not implemented for `(dyn FnOnce() -> u8 + 'static)` | ||
|
||
error[E0277]: the size for values of type `(dyn FnOnce() -> u8 + 'static)` cannot be known at compilation time | ||
--> $DIR/ice-unsized-tuple-const-issue-121443.rs:8:18 | ||
| | ||
LL | const TEST: Fn = some_fn; | ||
| ^^^^^^^ doesn't have a size known at compile-time | ||
| | ||
= help: the trait `Sized` is not implemented for `(dyn FnOnce() -> u8 + 'static)` | ||
= note: constant expressions must have a statically known size | ||
|
||
error[E0277]: the size for values of type `(dyn FnOnce() -> u8 + 'static)` cannot be known at compilation time | ||
--> $DIR/ice-unsized-tuple-const-issue-121443.rs:12:14 | ||
| | ||
LL | const TEST2: (Fn, u8) = (TEST, 0); | ||
| ^^^^^^^^ doesn't have a size known at compile-time | ||
| | ||
= help: the trait `Sized` is not implemented for `(dyn FnOnce() -> u8 + 'static)` | ||
= note: only the last element of a tuple may have a dynamically sized type | ||
|
||
error[E0277]: the size for values of type `(dyn FnOnce() -> u8 + 'static)` cannot be known at compilation time | ||
--> $DIR/ice-unsized-tuple-const-issue-121443.rs:12:25 | ||
| | ||
LL | const TEST2: (Fn, u8) = (TEST, 0); | ||
| ^^^^^^^^^ doesn't have a size known at compile-time | ||
| | ||
= help: within `((dyn FnOnce() -> u8 + 'static), u8)`, the trait `Sized` is not implemented for `(dyn FnOnce() -> u8 + 'static)`, which is required by `((dyn FnOnce() -> u8 + 'static), u8): Sized` | ||
= note: required because it appears within the type `((dyn FnOnce() -> u8 + 'static), u8)` | ||
= note: constant expressions must have a statically known size | ||
|
||
error: aborting due to 5 previous errors | ||
|
||
Some errors have detailed explanations: E0277, E0425. | ||
For more information about an error, try `rustc --explain E0277`. |
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
Oops, something went wrong.