aboutsummaryrefslogtreecommitdiff
path: root/gcc/rust/parse
diff options
context:
space:
mode:
authorPierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>2023-11-21 18:28:30 +0100
committerP-E-P <32375388+P-E-P@users.noreply.github.com>2023-11-29 23:37:08 +0000
commit3eb942857dfdfbc099d36fe878f55d9e690c143e (patch)
treefa80e63bb6eb2bd8557a117ee28d7c0316dabfb8 /gcc/rust/parse
parent2ab87ee89a3c5351d83e465e4061b40a51bb6c97 (diff)
downloadgcc-3eb942857dfdfbc099d36fe878f55d9e690c143e.zip
gcc-3eb942857dfdfbc099d36fe878f55d9e690c143e.tar.gz
gcc-3eb942857dfdfbc099d36fe878f55d9e690c143e.tar.bz2
Parse module safety
Unsafe module are rejected at a later stage but could not be parsed properly. This commit changes the parser in order to allow unsafe module in the AST. gcc/rust/ChangeLog: * parse/rust-parse-impl.h (Parser::parse_vis_item): Dispatch to parse module when meeting an unsafe module. (Parser::parse_module): Set unsafe status when the parser encounter an unsafe keyword. Signed-off-by: Pierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>
Diffstat (limited to 'gcc/rust/parse')
-rw-r--r--gcc/rust/parse/rust-parse-impl.h14
1 files changed, 11 insertions, 3 deletions
diff --git a/gcc/rust/parse/rust-parse-impl.h b/gcc/rust/parse/rust-parse-impl.h
index dfa0805..8258d6f 100644
--- a/gcc/rust/parse/rust-parse-impl.h
+++ b/gcc/rust/parse/rust-parse-impl.h
@@ -1418,6 +1418,8 @@ Parser<ManagedTokenSource>::parse_vis_item (AST::AttrVec outer_attrs)
return parse_function (std::move (vis), std::move (outer_attrs));
case IMPL:
return parse_impl (std::move (vis), std::move (outer_attrs));
+ case MOD:
+ return parse_module (std::move (vis), std::move (outer_attrs));
default:
add_error (
Error (t->get_locus (),
@@ -2427,6 +2429,13 @@ std::unique_ptr<AST::Module>
Parser<ManagedTokenSource>::parse_module (AST::Visibility vis,
AST::AttrVec outer_attrs)
{
+ Unsafety safety = Unsafety::Normal;
+ if (lexer.peek_token ()->get_id () == UNSAFE)
+ {
+ safety = Unsafety::Unsafe;
+ skip_token (UNSAFE);
+ }
+
location_t locus = lexer.peek_token ()->get_locus ();
skip_token (MOD);
@@ -2447,7 +2456,7 @@ Parser<ManagedTokenSource>::parse_module (AST::Visibility vis,
// Construct an external module
return std::unique_ptr<AST::Module> (
new AST::Module (std::move (name), std::move (vis),
- std::move (outer_attrs), locus, Unsafety::Normal,
+ std::move (outer_attrs), locus, safety,
lexer.get_filename (), inline_module_stack));
case LEFT_CURLY: {
lexer.skip_token ();
@@ -2504,8 +2513,7 @@ Parser<ManagedTokenSource>::parse_module (AST::Visibility vis,
return std::unique_ptr<AST::Module> (
new AST::Module (std::move (name), locus, std::move (items),
- std::move (vis), Unsafety::Normal,
- std::move (inner_attrs),
+ std::move (vis), safety, std::move (inner_attrs),
std::move (outer_attrs))); // module name?
}
default: