diff options
| author | Dylan DPC <dylan.dpc@gmail.com> | 2021-04-25 23:15:12 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-04-25 23:15:12 +0200 |
| commit | a0dcbdf7fd826bac839fc7c8097f807812cc02a0 (patch) | |
| tree | 1187ea3811adf2f61839db58b5247af3e886502c /src/test/codegen/src-hash-algorithm | |
| parent | 379a55c64ef72df1c8272ac33ba730244d1395d4 (diff) | |
| parent | fc97ce6daed320027a47c1a0ddb86c9242ebde0c (diff) | |
| download | rust-a0dcbdf7fd826bac839fc7c8097f807812cc02a0.tar.gz rust-a0dcbdf7fd826bac839fc7c8097f807812cc02a0.zip | |
Rollup merge of #84486 - Smittyvb:else-if-let-hir-pretty-print, r=petrochenkov
Handle pretty printing of `else if let` clauses without ICEing
When pretty printing the HIR of `if ... {} else if let ... {}` clauses, this displays it the `else if let` part as `match` it gets desugared to, the same way normal `if let` statements are currently displayed, instead of ICEing.
```rust
pub fn main() {
if true {
// 1
} else if let a = 1 {
// 2
} else {
// 3
}
}
```
now gets desugared (via `rustc -Zunpretty=hir,typed src/x.rs`) to:
```rust
#[prelude_import]
use ::std::prelude::rust_2015::*;
#[macro_use]
extern crate std;
pub fn main() ({
(if (true as bool)
({
// 1
} as
()) else {match (1 as i32) {
a => {
// 2
}
_ => {
// 3
}
}} as ())
} as ())
```
For comparison, this code gets HIR prettyprinted the same way before and after this change:
```rust
pub fn main() {
if let a = 1 {
// 2
} else {
// 3
}
}
```
turns into
```rust
#[prelude_import]
use ::std::prelude::rust_2015::*;
#[macro_use]
extern crate std;
pub fn main() ({
(match (1 as i32) {
a => {
// 2
}
_ => {
// 3
}
} as ())
} as ())
```
This closes #82329. It closes #84434 as well, due to having the same root cause.
Diffstat (limited to 'src/test/codegen/src-hash-algorithm')
0 files changed, 0 insertions, 0 deletions
