diff options
author | bors[bot] <26634292+bors[bot]@users.noreply.github.com> | 2022-05-10 10:16:06 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-05-10 10:16:06 +0000 |
commit | 03c21a08eb40b71e67da0c8ae83ed2c645fb76a3 (patch) | |
tree | 94cfffeebc846d1f6ff414e205a3011a29da8ac8 /gcc/rust/hir/rust-ast-lower-block.h | |
parent | ba3f9811192cbbfe7b9a8256ca76f160f64063b7 (diff) | |
parent | 245215bf8d11025dfca3c7003ce10151aa7ba4e4 (diff) | |
download | gcc-03c21a08eb40b71e67da0c8ae83ed2c645fb76a3.zip gcc-03c21a08eb40b71e67da0c8ae83ed2c645fb76a3.tar.gz gcc-03c21a08eb40b71e67da0c8ae83ed2c645fb76a3.tar.bz2 |
Merge #1218
1218: Lower IfLet expressions r=CohenArthur a=antego
This PR addresses https://github.com/Rust-GCC/gccrs/issues/1177. This change implements the "hir-lowering" part of the plan outlined here https://github.com/Rust-GCC/gccrs/issues/1177#issuecomment-1118530135.
Co-authored-by: antego <antego@users.noreply.github.com>
Diffstat (limited to 'gcc/rust/hir/rust-ast-lower-block.h')
-rw-r--r-- | gcc/rust/hir/rust-ast-lower-block.h | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/gcc/rust/hir/rust-ast-lower-block.h b/gcc/rust/hir/rust-ast-lower-block.h index 512f4709..5c328b5 100644 --- a/gcc/rust/hir/rust-ast-lower-block.h +++ b/gcc/rust/hir/rust-ast-lower-block.h @@ -120,6 +120,35 @@ private: bool terminated; }; +class ASTLoweringIfLetBlock : public ASTLoweringBase +{ + using Rust::HIR::ASTLoweringBase::visit; + +public: + static HIR::IfLetExpr *translate (AST::IfLetExpr *expr) + { + ASTLoweringIfLetBlock resolver; + expr->accept_vis (resolver); + if (resolver.translated != nullptr) + { + resolver.mappings->insert_hir_expr ( + resolver.translated->get_mappings ().get_crate_num (), + resolver.translated->get_mappings ().get_hirid (), + resolver.translated); + } + return resolver.translated; + } + + ~ASTLoweringIfLetBlock () {} + + void visit (AST::IfLetExpr &expr) override; + +private: + ASTLoweringIfLetBlock () : ASTLoweringBase (), translated (nullptr) {} + + HIR::IfLetExpr *translated; +}; + class ASTLoweringExprWithBlock : public ASTLoweringBase { using Rust::HIR::ASTLoweringBase::visit; @@ -159,6 +188,11 @@ public: translated = ASTLoweringIfBlock::translate (&expr, &terminated); } + void visit (AST::IfLetExpr &expr) override + { + translated = ASTLoweringIfLetBlock::translate (&expr); + } + void visit (AST::BlockExpr &expr) override { translated = ASTLoweringBlock::translate (&expr, &terminated); |