Skip to content

Commit

Permalink
Added support to Parse ASYNC function
Browse files Browse the repository at this point in the history
Fixes issue #2650
The parser now parses ASYNC functions. Added ASYNC case to parse_item
Added a new function parse_async_item which is called in
parse_vis_item to handle the ASYNC case. Parse_async_item
also checks the current Rust edition and generates an error if the
edition is 2015.

gcc/rust/ChangeLog:

	* parse/rust-parse-impl.h (Parser::parse_item): Likewise.
	(Parser::parse_vis_item): Likewise.
	(Parser::parse_async_item): Likewise.
	* parse/rust-parse.h: Made declaration for parse_async_item.

gcc/testsuite/ChangeLog:

	* rust/compile/issue-2650-1.rs: New test.(edition=2018)
	* rust/compile/issue-2650-2.rs: New test.(edition=2015)

Signed-off-by: M V V S Manoj Kumar <[email protected]>
  • Loading branch information
mvvsmk committed Nov 16, 2023
1 parent 005d5e1 commit 13ae099
Show file tree
Hide file tree
Showing 4 changed files with 54 additions and 0 deletions.
41 changes: 41 additions & 0 deletions gcc/rust/parse/rust-parse-impl.h
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
#include "rust-dir-owner.h"
#include "rust-attribute-values.h"
#include "rust-keyword-values.h"
#include "rust-session-manager.h"

#include "optional.h"

Expand Down Expand Up @@ -1111,6 +1112,8 @@ Parser<ManagedTokenSource>::parse_item (bool called_from_statement)
add_error (std::move (error));
}
return nullptr;

case ASYNC:
case PUB:
case MOD:
case EXTERN_TOK:
Expand Down Expand Up @@ -1387,6 +1390,10 @@ Parser<ManagedTokenSource>::parse_vis_item (AST::AttrVec outer_attrs)
lexer.skip_token (1); // TODO: is this right thing to do?
return nullptr;
}
// for async functions
case ASYNC:
return parse_async_item (std::move (vis), std::move (outer_attrs));

case STATIC_TOK:
return parse_static_item (std::move (vis), std::move (outer_attrs));
case AUTO:
Expand Down Expand Up @@ -1427,6 +1434,40 @@ Parser<ManagedTokenSource>::parse_vis_item (AST::AttrVec outer_attrs)
return nullptr;
}

template <typename ManagedTokenSource>
std::unique_ptr<AST::Function>
Parser<ManagedTokenSource>::parse_async_item (AST::Visibility vis,
AST::AttrVec outer_attrs)
{
const_TokenPtr t = lexer.peek_token ();
if (Session::get_instance ().options.get_edition ()
== CompileOptions::Edition::E2015)
{
add_error (Error (Error::Kind::Err, t->get_locus (), ErrorCode::E0670,
"\'async fn\' is not permitted in Rust 2015"));
add_error (
Error::Hint (t->get_locus (),
"to use \'async fn\', switch to Rust 2018 or later"));
}

t = lexer.peek_token (1);

switch (t->get_id ())
{
case UNSAFE:
case FN_TOK:
return parse_function (std::move (vis), std::move (outer_attrs));

default:
add_error (Error (t->get_locus (),
"unexpected token %qs in some sort of async production",
t->get_token_description ()));

lexer.skip_token (1);
return nullptr;
}
}

// Parses a macro rules definition syntax extension whatever thing.
template <typename ManagedTokenSource>
std::unique_ptr<AST::MacroRulesDefinition>
Expand Down
2 changes: 2 additions & 0 deletions gcc/rust/parse/rust-parse.h
Original file line number Diff line number Diff line change
Expand Up @@ -346,6 +346,8 @@ template <typename ManagedTokenSource> class Parser
std::unique_ptr<AST::ExternBlock>
parse_extern_block (AST::Visibility vis, AST::AttrVec outer_attrs);
std::unique_ptr<AST::Function> parse_method ();
std::unique_ptr<AST::Function> parse_async_item (AST::Visibility vis,
AST::AttrVec outer_attrs);

// Expression-related (Pratt parsed)
std::unique_ptr<AST::Expr>
Expand Down
5 changes: 5 additions & 0 deletions gcc/testsuite/rust/compile/issue-2650-1.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
// { dg-additional-options "-frust-edition=2018" }

pub async fn a() -> u32 {
1
}
6 changes: 6 additions & 0 deletions gcc/testsuite/rust/compile/issue-2650-2.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
// { dg-additional-options "-frust-edition=2015" }

// { dg-excess-errors "'async fn' is not permitted in Rust 2015" }
pub async fn a() -> u32 {
1
}

0 comments on commit 13ae099

Please sign in to comment.