aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorPierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>2023-03-22 16:17:42 +0100
committerArthur Cohen <arthur.cohen@embecosm.com>2023-03-30 16:48:26 +0200
commitbea0c13139d48294d26f0a72401d6e3fb6a48d77 (patch)
treef80064e37b2136b0c27321acc510f697f0409386 /gcc
parentf9fcd37d055c8e46aaecfa4a5af91e0108670c17 (diff)
downloadgcc-bea0c13139d48294d26f0a72401d6e3fb6a48d77.zip
gcc-bea0c13139d48294d26f0a72401d6e3fb6a48d77.tar.gz
gcc-bea0c13139d48294d26f0a72401d6e3fb6a48d77.tar.bz2
ast: Add Tokenstream visitors for loop expressions
Add the implementation of tokenstream dump for multiple loop expressions. gcc/rust/ChangeLog: * ast/rust-ast-tokenstream.cc (TokenStream::visit): Add visitors. (TokenStream::visit_loop_common): Merge common loop code. * ast/rust-ast-tokenstream.h: Add function prototypes. Signed-off-by: Pierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>
Diffstat (limited to 'gcc')
-rw-r--r--gcc/rust/ast/rust-ast-tokenstream.cc73
-rw-r--r--gcc/rust/ast/rust-ast-tokenstream.h3
2 files changed, 64 insertions, 12 deletions
diff --git a/gcc/rust/ast/rust-ast-tokenstream.cc b/gcc/rust/ast/rust-ast-tokenstream.cc
index 18337ac..c93c24c 100644
--- a/gcc/rust/ast/rust-ast-tokenstream.cc
+++ b/gcc/rust/ast/rust-ast-tokenstream.cc
@@ -1179,28 +1179,77 @@ TokenStream::visit (RangeToInclExpr &expr)
}
void
-TokenStream::visit (ReturnExpr &)
-{}
+TokenStream::visit (ReturnExpr &expr)
+{
+ tokens.push_back (Rust::Token::make (RETURN_TOK, expr.get_locus ()));
+ if (expr.has_returned_expr ())
+ visit (expr.get_returned_expr ());
+}
void
-TokenStream::visit (UnsafeBlockExpr &)
-{}
+TokenStream::visit (UnsafeBlockExpr &expr)
+{
+ tokens.push_back (Rust::Token::make (UNSAFE, expr.get_locus ()));
+ visit (expr.get_block_expr ());
+}
void
-TokenStream::visit (LoopExpr &)
-{}
+TokenStream::visit (LoopLabel &label)
+{
+ visit (label.get_lifetime ());
+ tokens.push_back (Rust::Token::make (COLON, label.get_locus ()));
+}
void
-TokenStream::visit (WhileLoopExpr &)
-{}
+TokenStream::visit_loop_common (BaseLoopExpr &expr)
+{
+ if (expr.has_loop_label ())
+ visit (expr.get_loop_label ());
+}
void
-TokenStream::visit (WhileLetLoopExpr &)
-{}
+TokenStream::visit (LoopExpr &expr)
+{
+ visit_loop_common (expr);
+ tokens.push_back (Rust::Token::make (LOOP, expr.get_locus ()));
+ visit (expr.get_loop_block ());
+}
void
-TokenStream::visit (ForLoopExpr &)
-{}
+TokenStream::visit (WhileLoopExpr &expr)
+{
+ visit_loop_common (expr);
+ tokens.push_back (Rust::Token::make (WHILE, expr.get_locus ()));
+ visit (expr.get_predicate_expr ());
+ visit (expr.get_loop_block ());
+}
+
+void
+TokenStream::visit (WhileLetLoopExpr &expr)
+{
+ visit_loop_common (expr);
+ tokens.push_back (Rust::Token::make (WHILE, expr.get_locus ()));
+ tokens.push_back (Rust::Token::make (LET, Location ()));
+ // TODO: The reference mention only one Pattern
+ for (auto &item : expr.get_patterns ())
+ {
+ visit (item);
+ }
+ tokens.push_back (Rust::Token::make (EQUAL, Location ()));
+ visit (expr.get_scrutinee_expr ());
+ visit (expr.get_loop_block ());
+}
+
+void
+TokenStream::visit (ForLoopExpr &expr)
+{
+ visit_loop_common (expr);
+ tokens.push_back (Rust::Token::make (FOR, expr.get_locus ()));
+ visit (expr.get_pattern ());
+ tokens.push_back (Rust::Token::make (IN, Location ()));
+ visit (expr.get_iterator_expr ());
+ visit (expr.get_loop_block ());
+}
void
TokenStream::visit (IfExpr &expr)
diff --git a/gcc/rust/ast/rust-ast-tokenstream.h b/gcc/rust/ast/rust-ast-tokenstream.h
index 58b90fb..c8a6982 100644
--- a/gcc/rust/ast/rust-ast-tokenstream.h
+++ b/gcc/rust/ast/rust-ast-tokenstream.h
@@ -94,6 +94,9 @@ private:
void visit_function_common (std::unique_ptr<Type> &return_type,
std::unique_ptr<BlockExpr> &block);
+ void visit_loop_common (BaseLoopExpr &expr);
+ void visit (LoopLabel &label);
+
void visit (Literal &lit, Location locus = {});
void visit (FunctionParam &param);