diff options
author | chriseth <c@ethdev.com> | 2016-02-22 09:13:32 +0800 |
---|---|---|
committer | chriseth <c@ethdev.com> | 2016-02-23 01:02:29 +0800 |
commit | 968934c05d260cb3149cbcd57014701a32987480 (patch) | |
tree | 72496c588192d4677d9127ba8b6e8d36e7408860 /libsolidity/parsing/ParserBase.cpp | |
parent | 37381072dec7636bd4648cbc291ae79c1b1fa450 (diff) | |
download | dexon-solidity-968934c05d260cb3149cbcd57014701a32987480.tar.gz dexon-solidity-968934c05d260cb3149cbcd57014701a32987480.tar.zst dexon-solidity-968934c05d260cb3149cbcd57014701a32987480.zip |
Move reusable parser components into base class.
Diffstat (limited to 'libsolidity/parsing/ParserBase.cpp')
-rw-r--r-- | libsolidity/parsing/ParserBase.cpp | 103 |
1 files changed, 103 insertions, 0 deletions
diff --git a/libsolidity/parsing/ParserBase.cpp b/libsolidity/parsing/ParserBase.cpp new file mode 100644 index 00000000..64e42841 --- /dev/null +++ b/libsolidity/parsing/ParserBase.cpp @@ -0,0 +1,103 @@ +/* + This file is part of cpp-ethereum. + + cpp-ethereum is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + cpp-ethereum is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with cpp-ethereum. If not, see <http://www.gnu.org/licenses/>. +*/ +/** + * @author Christian <c@ethdev.com> + * @date 2016 + * Solidity parser shared functionality. + */ + +#include <libsolidity/parsing/ParserBase.h> +#include <libsolidity/parsing/Scanner.h> + +using namespace std; +using namespace dev; +using namespace dev::solidity; + +std::shared_ptr<string const> const& ParserBase::sourceName() const +{ + return m_scanner->sourceName(); +} + +int ParserBase::position() const +{ + return m_scanner->currentLocation().start; +} + +int ParserBase::endPosition() const +{ + return m_scanner->currentLocation().end; +} + +void ParserBase::expectToken(Token::Value _value) +{ + if (m_scanner->currentToken() != _value) + fatalParserError( + string("Expected token ") + + string(Token::name(_value)) + + string(" got '") + + string(Token::name(m_scanner->currentToken())) + + string("'") + ); + m_scanner->next(); +} + +Token::Value ParserBase::expectAssignmentOperator() +{ + Token::Value op = m_scanner->currentToken(); + if (!Token::isAssignmentOp(op)) + fatalParserError( + string("Expected assignment operator, got '") + + string(Token::name(m_scanner->currentToken())) + + string("'") + ); + m_scanner->next(); + return op; +} + +ASTPointer<ASTString> ParserBase::expectIdentifierToken() +{ + if (m_scanner->currentToken() != Token::Identifier) + fatalParserError( + string("Expected identifier, got '") + + string(Token::name(m_scanner->currentToken())) + + string("'") + ); + return getLiteralAndAdvance(); +} + +ASTPointer<ASTString> ParserBase::getLiteralAndAdvance() +{ + ASTPointer<ASTString> identifier = make_shared<ASTString>(m_scanner->currentLiteral()); + m_scanner->next(); + return identifier; +} + +void ParserBase::parserError(string const& _description) +{ + auto err = make_shared<Error>(Error::Type::ParserError); + *err << + errinfo_sourceLocation(SourceLocation(position(), position(), sourceName())) << + errinfo_comment(_description); + + m_errors.push_back(err); +} + +void ParserBase::fatalParserError(string const& _description) +{ + parserError(_description); + BOOST_THROW_EXCEPTION(FatalError()); +} |