From 4f6f827e26ffcb9b850ef8a8b7f7b4beb5addb7a Mon Sep 17 00:00:00 2001 From: Yong He Date: Tue, 27 Aug 2024 18:48:41 -0700 Subject: Add functor syntax support. (#4926) --- source/slang/slang-parser.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) (limited to 'source/slang/slang-parser.cpp') diff --git a/source/slang/slang-parser.cpp b/source/slang/slang-parser.cpp index 5881e5796..b3a18f8a8 100644 --- a/source/slang/slang-parser.cpp +++ b/source/slang/slang-parser.cpp @@ -1367,6 +1367,9 @@ namespace Slang case TokenType::Comma: case TokenType::OpAssign: break; + case TokenType::LParent: + parser->ReadToken(TokenType::RParent); + break; // Note(tfoley): Even more of a hack! case TokenType::QuestionMark: @@ -1382,6 +1385,9 @@ namespace Slang break; } + if (nameToken.type == TokenType::LParent) + return NameLoc(getName(parser, "()"), nameToken.loc); + return NameLoc( getName(parser, nameToken.getContent()), nameToken.loc); @@ -7051,7 +7057,7 @@ namespace Slang varExpr->scope = parser->currentScope; parser->FillPosition(varExpr); - auto nameAndLoc = NameLoc(parser->ReadToken()); + auto nameAndLoc = ParseDeclName(parser); varExpr->name = nameAndLoc.name; if(peekTokenType(parser) == TokenType::OpLess) @@ -7177,7 +7183,7 @@ namespace Slang memberExpr->baseExpression = expr; parser->ReadToken(nextTokenType); parser->FillPosition(memberExpr); - memberExpr->name = expectIdentifier(parser).name; + memberExpr->name = ParseDeclName(parser).name; if (peekTokenType(parser) == TokenType::OpLess) expr = maybeParseGenericApp(parser, memberExpr); -- cgit v1.2.3