From: Pierre-Emmanuel Patry Date: Wed, 8 Nov 2023 15:50:50 +0000 (+0100) Subject: gccrs: Add validation pass for label name X-Git-Tag: basepoints/gcc-15~1996 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=93ca83c5efd6908b6c5602642004d0364bf9144b;p=thirdparty%2Fgcc.git gccrs: Add validation pass for label name Prevent from using reserved keyword in label name. gcc/rust/ChangeLog: * ast/rust-ast-visitor.cc (DefaultASTVisitor::visit): Check if there is a label before visit. * checks/errors/rust-ast-validation.cc (ASTValidation::visit): Emit an error when a label has a forbidden name. * checks/errors/rust-ast-validation.h: Add function prototype. Signed-off-by: Pierre-Emmanuel Patry --- diff --git a/gcc/rust/ast/rust-ast-visitor.cc b/gcc/rust/ast/rust-ast-visitor.cc index 63f850f8c7c2..b9ff2f972803 100644 --- a/gcc/rust/ast/rust-ast-visitor.cc +++ b/gcc/rust/ast/rust-ast-visitor.cc @@ -494,7 +494,9 @@ void DefaultASTVisitor::visit (AST::BreakExpr &expr) { visit_outer_attrs (expr); - visit (expr.get_label ()); + if (expr.has_label ()) + visit (expr.get_label ()); + if (expr.has_break_expr ()) visit (expr.get_break_expr ()); } diff --git a/gcc/rust/checks/errors/rust-ast-validation.cc b/gcc/rust/checks/errors/rust-ast-validation.cc index 3af5655d7f31..44dec61b921b 100644 --- a/gcc/rust/checks/errors/rust-ast-validation.cc +++ b/gcc/rust/checks/errors/rust-ast-validation.cc @@ -36,6 +36,21 @@ ASTValidation::visit (AST::Lifetime &lifetime) AST::ContextualASTVisitor::visit (lifetime); } +void +ASTValidation::visit (AST::LoopLabel &label) +{ + auto name = label.get_lifetime ().get_lifetime_name (); + auto lifetime_name = '\'' + name; + auto &keywords = Values::Keywords::keywords; + if (keywords.find (name) != keywords.end ()) + rust_error_at (label.get_locus (), "invalid label name %qs", + lifetime_name.c_str ()); + + // WARNING: Do not call ContextualASTVisitor, we don't want to visit the + // lifetime + // Maybe we should refactor LoopLabel instead ? +} + void ASTValidation::visit (AST::ConstantItem &const_item) { diff --git a/gcc/rust/checks/errors/rust-ast-validation.h b/gcc/rust/checks/errors/rust-ast-validation.h index ef0b2ac05386..a21bcc44f68b 100644 --- a/gcc/rust/checks/errors/rust-ast-validation.h +++ b/gcc/rust/checks/errors/rust-ast-validation.h @@ -35,6 +35,7 @@ public: virtual void visit (AST::ConstantItem &const_item); virtual void visit (AST::Lifetime &lifetime); + virtual void visit (AST::LoopLabel &label); }; } // namespace Rust