aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorThomas Young <wenzhang5800@gmail.com>2022-05-21 21:23:55 +0800
committerThomas Young <wenzhang5800@gmail.com>2022-05-21 21:23:55 +0800
commit75c9f9f61cb2d69f39d490c47a3b42810c31c1ff (patch)
treec81b6f062feeee69a877b51f24b1932132b0d961 /gcc
parent5ad0ea3e0ed288569d52556b9aa796beea73d8a3 (diff)
downloadgcc-75c9f9f61cb2d69f39d490c47a3b42810c31c1ff.zip
gcc-75c9f9f61cb2d69f39d490c47a3b42810c31c1ff.tar.gz
gcc-75c9f9f61cb2d69f39d490c47a3b42810c31c1ff.tar.bz2
Marklive: support match expr
Diffstat (limited to 'gcc')
-rw-r--r--gcc/rust/hir/tree/rust-hir-expr.h6
-rw-r--r--gcc/rust/lint/rust-lint-marklive.h15
-rw-r--r--gcc/testsuite/rust/compile/match6.rs21
3 files changed, 42 insertions, 0 deletions
diff --git a/gcc/rust/hir/tree/rust-hir-expr.h b/gcc/rust/hir/tree/rust-hir-expr.h
index e585dd2..f6f035e 100644
--- a/gcc/rust/hir/tree/rust-hir-expr.h
+++ b/gcc/rust/hir/tree/rust-hir-expr.h
@@ -3842,6 +3842,12 @@ public:
return match_arm_patterns;
}
+ std::unique_ptr<Expr> &get_guard_expr ()
+ {
+ rust_assert (has_match_arm_guard ());
+ return guard_expr;
+ }
+
Location get_locus () const { return locus; }
};
diff --git a/gcc/rust/lint/rust-lint-marklive.h b/gcc/rust/lint/rust-lint-marklive.h
index aeecda5..89a6d7e 100644
--- a/gcc/rust/lint/rust-lint-marklive.h
+++ b/gcc/rust/lint/rust-lint-marklive.h
@@ -204,6 +204,21 @@ public:
expr.get_else_block ()->accept_vis (*this);
}
+ void visit (HIR::MatchExpr &expr) override
+ {
+ expr.get_scrutinee_expr ()->accept_vis (*this);
+ std::vector<HIR::MatchCase> &cases = expr.get_match_cases ();
+ for (auto &&caz : cases)
+ {
+ auto case_arm = caz.get_arm ();
+ if (case_arm.has_match_arm_guard ())
+ {
+ case_arm.get_guard_expr ()->accept_vis (*this);
+ }
+ caz.get_expr ()->accept_vis (*this);
+ }
+ }
+
void visit (HIR::IfExprConseqIf &expr) override
{
expr.get_if_condition ()->accept_vis (*this);
diff --git a/gcc/testsuite/rust/compile/match6.rs b/gcc/testsuite/rust/compile/match6.rs
new file mode 100644
index 0000000..eec775b
--- /dev/null
+++ b/gcc/testsuite/rust/compile/match6.rs
@@ -0,0 +1,21 @@
+fn foo() -> bool {
+ true
+}
+
+fn int32() -> i32 {
+ 1
+}
+
+fn bar() -> i32 {
+ match foo() {
+ true => int32(),
+ false => 0
+ }
+}
+
+fn main() -> () {
+ bar();
+}
+
+
+