diff options
| author | Matthias Krüger <matthias.krueger@famsik.de> | 2022-10-07 07:28:12 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-10-07 07:28:12 +0200 |
| commit | a09e2f6753078f3ab40b02e8c184d9b2fe07f342 (patch) | |
| tree | 24b9a8a33e2dae873270133d8916c63344728de0 | |
| parent | 04459f7a6ac04ca0adb98b04e5fca38e5760e00a (diff) | |
| parent | 58fb351cad389b660c82966e28e213e77dfc1c57 (diff) | |
| download | rust-a09e2f6753078f3ab40b02e8c184d9b2fe07f342.tar.gz rust-a09e2f6753078f3ab40b02e8c184d9b2fe07f342.zip | |
Rollup merge of #102761 - est31:let_else_uninhabited_test, r=compiler-errors
let-else: test else block with non-never uninhabited type let else currently does not allow uninhabited types for the `else` block that aren't `!`. One can maybe think about relaxing this in the future, but if it is done, it should be an explicit choice and not an unexpected side effect of e.g. a refactor. Thus, I'm extending a test that will fail if the behaviour changes.
| -rw-r--r-- | src/test/ui/let-else/let-else-non-diverging.rs | 11 | ||||
| -rw-r--r-- | src/test/ui/let-else/let-else-non-diverging.stderr | 13 |
2 files changed, 23 insertions, 1 deletions
diff --git a/src/test/ui/let-else/let-else-non-diverging.rs b/src/test/ui/let-else/let-else-non-diverging.rs index b5bd91ceb9e..58d2c09776f 100644 --- a/src/test/ui/let-else/let-else-non-diverging.rs +++ b/src/test/ui/let-else/let-else-non-diverging.rs @@ -8,4 +8,15 @@ fn main() { } }; let Some(x) = Some(1) else { Some(2) }; //~ ERROR does not diverge + + // Ensure that uninhabited types do not "diverge". + // This might be relaxed in the future, but when it is, + // it should be an explicitly wanted descision. + let Some(x) = Some(1) else { foo::<Uninhabited>() }; //~ ERROR does not diverge +} + +enum Uninhabited {} + +fn foo<T>() -> T { + panic!() } diff --git a/src/test/ui/let-else/let-else-non-diverging.stderr b/src/test/ui/let-else/let-else-non-diverging.stderr index c999a549525..78551fcc434 100644 --- a/src/test/ui/let-else/let-else-non-diverging.stderr +++ b/src/test/ui/let-else/let-else-non-diverging.stderr @@ -39,6 +39,17 @@ LL | let Some(x) = Some(1) else { Some(2) }; = help: try adding a diverging expression, such as `return` or `panic!(..)` = help: ...or use `match` instead of `let...else` -error: aborting due to 3 previous errors +error[E0308]: `else` clause of `let...else` does not diverge + --> $DIR/let-else-non-diverging.rs:15:32 + | +LL | let Some(x) = Some(1) else { foo::<Uninhabited>() }; + | ^^^^^^^^^^^^^^^^^^^^^^^^ expected `!`, found enum `Uninhabited` + | + = note: expected type `!` + found enum `Uninhabited` + = help: try adding a diverging expression, such as `return` or `panic!(..)` + = help: ...or use `match` instead of `let...else` + +error: aborting due to 4 previous errors For more information about this error, try `rustc --explain E0308`. |
