|
@ -231,15 +231,33 @@ ptr<ParameterList> Parser::parseParameterList() |
|
|
|
|
|
|
|
|
ptr<Block> Parser::parseBlock() |
|
|
ptr<Block> Parser::parseBlock() |
|
|
{ |
|
|
{ |
|
|
|
|
|
|
|
|
ASTNodeFactory nodeFactory(*this); |
|
|
ASTNodeFactory nodeFactory(*this); |
|
|
expectToken(Token::LBRACE); |
|
|
expectToken(Token::LBRACE); |
|
|
|
|
|
vecptr<Statement> statements; |
|
|
while (m_scanner->getCurrentToken() != Token::RBRACE) { |
|
|
while (m_scanner->getCurrentToken() != Token::RBRACE) { |
|
|
m_scanner->next(); |
|
|
m_scanner->next(); |
|
|
// @todo
|
|
|
statements.push_back(parseStatement()); |
|
|
} |
|
|
} |
|
|
nodeFactory.markEndPosition(); |
|
|
nodeFactory.markEndPosition(); |
|
|
expectToken(Token::RBRACE); |
|
|
expectToken(Token::RBRACE); |
|
|
return nodeFactory.createNode<Block>(); |
|
|
return nodeFactory.createNode<Block>(statements); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
ptr<Statement> Parser::parseStatement() |
|
|
|
|
|
{ |
|
|
|
|
|
|
|
|
|
|
|
switch (m_scanner->getCurrentToken()) { |
|
|
|
|
|
case Token::IF: |
|
|
|
|
|
return parseIfStatement(); |
|
|
|
|
|
case Token::WHILE: |
|
|
|
|
|
return parseWhileStatement(); |
|
|
|
|
|
case Token::LBRACE: |
|
|
|
|
|
return parseBlock(); |
|
|
|
|
|
// starting from here, all statements must be terminated by a semicolon
|
|
|
|
|
|
case Token::CONTINUE: // all following
|
|
|
|
|
|
return |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void Parser::expectToken(Token::Value _value) |
|
|
void Parser::expectToken(Token::Value _value) |
|
|