aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/rust/hir/rust-ast-lower-block.h34
-rw-r--r--gcc/rust/hir/rust-ast-lower.cc28
2 files changed, 62 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);
diff --git a/gcc/rust/hir/rust-ast-lower.cc b/gcc/rust/hir/rust-ast-lower.cc
index d861207..d8a0488 100644
--- a/gcc/rust/hir/rust-ast-lower.cc
+++ b/gcc/rust/hir/rust-ast-lower.cc
@@ -223,6 +223,34 @@ ASTLoweringIfBlock::visit (AST::IfExprConseqIf &expr)
expr.get_locus ());
}
+void
+ASTLoweringIfLetBlock::visit (AST::IfLetExpr &expr)
+{
+ std::vector<std::unique_ptr<HIR::Pattern> > patterns;
+ for (auto &pattern : expr.get_patterns ())
+ {
+ HIR::Pattern *ptrn = ASTLoweringPattern::translate (pattern.get ());
+ patterns.push_back (std::unique_ptr<HIR::Pattern> (ptrn));
+ }
+ HIR::Expr *value_ptr
+ = ASTLoweringExpr::translate (expr.get_value_expr ().get ());
+
+ bool ignored_terminated = false;
+ HIR::BlockExpr *block
+ = ASTLoweringBlock::translate (expr.get_if_block ().get (),
+ &ignored_terminated);
+
+ auto crate_num = mappings->get_current_crate ();
+ Analysis::NodeMapping mapping (crate_num, expr.get_node_id (),
+ mappings->get_next_hir_id (crate_num),
+ UNKNOWN_LOCAL_DEFID);
+
+ translated = new HIR::IfLetExpr (mapping, std::move (patterns),
+ std::unique_ptr<HIR::Expr> (value_ptr),
+ std::unique_ptr<HIR::BlockExpr> (block),
+ expr.get_locus ());
+}
+
// rust-ast-lower-struct-field-expr.h
void