mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Factor out tokenToContractKind
This commit is contained in:
parent
3f1468142b
commit
f8da9a8fd5
@ -194,6 +194,23 @@ ASTPointer<ImportDirective> Parser::parseImportDirective()
|
|||||||
return nodeFactory.createNode<ImportDirective>(path, unitAlias, move(symbolAliases));
|
return nodeFactory.createNode<ImportDirective>(path, unitAlias, move(symbolAliases));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ContractDefinition::ContractKind Parser::tokenToContractKind(Token::Value _token)
|
||||||
|
{
|
||||||
|
switch(_token)
|
||||||
|
{
|
||||||
|
case Token::Interface:
|
||||||
|
return ContractDefinition::ContractKind::Interface;
|
||||||
|
case Token::Contract:
|
||||||
|
return ContractDefinition::ContractKind::Contract;
|
||||||
|
case Token::Library:
|
||||||
|
return ContractDefinition::ContractKind::Library;
|
||||||
|
default:
|
||||||
|
fatalParserError("Unsupported contract type.");
|
||||||
|
}
|
||||||
|
// FIXME: fatalParserError is not considered as throwing here
|
||||||
|
return ContractDefinition::ContractKind::Contract;
|
||||||
|
}
|
||||||
|
|
||||||
ASTPointer<ContractDefinition> Parser::parseContractDefinition(Token::Value _expectedKind)
|
ASTPointer<ContractDefinition> Parser::parseContractDefinition(Token::Value _expectedKind)
|
||||||
{
|
{
|
||||||
ASTNodeFactory nodeFactory(*this);
|
ASTNodeFactory nodeFactory(*this);
|
||||||
@ -201,21 +218,6 @@ ASTPointer<ContractDefinition> Parser::parseContractDefinition(Token::Value _exp
|
|||||||
if (m_scanner->currentCommentLiteral() != "")
|
if (m_scanner->currentCommentLiteral() != "")
|
||||||
docString = make_shared<ASTString>(m_scanner->currentCommentLiteral());
|
docString = make_shared<ASTString>(m_scanner->currentCommentLiteral());
|
||||||
expectToken(_expectedKind);
|
expectToken(_expectedKind);
|
||||||
ContractDefinition::ContractKind contractKind;
|
|
||||||
switch(_expectedKind)
|
|
||||||
{
|
|
||||||
case Token::Interface:
|
|
||||||
contractKind = ContractDefinition::ContractKind::Interface;
|
|
||||||
break;
|
|
||||||
case Token::Contract:
|
|
||||||
contractKind = ContractDefinition::ContractKind::Contract;
|
|
||||||
break;
|
|
||||||
case Token::Library:
|
|
||||||
contractKind = ContractDefinition::ContractKind::Library;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
fatalParserError("Unsupported contract type.");
|
|
||||||
}
|
|
||||||
ASTPointer<ASTString> name = expectIdentifierToken();
|
ASTPointer<ASTString> name = expectIdentifierToken();
|
||||||
vector<ASTPointer<InheritanceSpecifier>> baseContracts;
|
vector<ASTPointer<InheritanceSpecifier>> baseContracts;
|
||||||
if (m_scanner->currentToken() == Token::Is)
|
if (m_scanner->currentToken() == Token::Is)
|
||||||
@ -268,7 +270,7 @@ ASTPointer<ContractDefinition> Parser::parseContractDefinition(Token::Value _exp
|
|||||||
docString,
|
docString,
|
||||||
baseContracts,
|
baseContracts,
|
||||||
subNodes,
|
subNodes,
|
||||||
contractKind
|
tokenToContractKind(_expectedKind)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,6 +69,7 @@ private:
|
|||||||
///@name Parsing functions for the AST nodes
|
///@name Parsing functions for the AST nodes
|
||||||
ASTPointer<PragmaDirective> parsePragmaDirective();
|
ASTPointer<PragmaDirective> parsePragmaDirective();
|
||||||
ASTPointer<ImportDirective> parseImportDirective();
|
ASTPointer<ImportDirective> parseImportDirective();
|
||||||
|
ContractDefinition::ContractKind tokenToContractKind(Token::Value _token);
|
||||||
ASTPointer<ContractDefinition> parseContractDefinition(Token::Value _expectedKind);
|
ASTPointer<ContractDefinition> parseContractDefinition(Token::Value _expectedKind);
|
||||||
ASTPointer<InheritanceSpecifier> parseInheritanceSpecifier();
|
ASTPointer<InheritanceSpecifier> parseInheritanceSpecifier();
|
||||||
Declaration::Visibility parseVisibilitySpecifier(Token::Value _token);
|
Declaration::Visibility parseVisibilitySpecifier(Token::Value _token);
|
||||||
|
Loading…
Reference in New Issue
Block a user