From c002fcc39f2322516fe0bd79a0d3583a6e9de979 Mon Sep 17 00:00:00 2001 From: Alex Beregszaszi Date: Tue, 3 Nov 2020 23:39:29 +0000 Subject: [PATCH 1/2] Untangle headers and namespaces in TestFileParser --- test/libsolidity/util/BytesUtils.cpp | 2 -- test/libsolidity/util/ContractABIUtils.cpp | 1 - test/libsolidity/util/SoltestTypes.h | 1 - test/libsolidity/util/TestFileParser.cpp | 16 +++++++--------- test/libsolidity/util/TestFileParser.h | 4 +--- test/libsolidity/util/TestFunctionCall.cpp | 7 ++----- test/libsolidity/util/TestFunctionCall.h | 1 - 7 files changed, 10 insertions(+), 22 deletions(-) diff --git a/test/libsolidity/util/BytesUtils.cpp b/test/libsolidity/util/BytesUtils.cpp index e3a6fd4ed..d8892a4a7 100644 --- a/test/libsolidity/util/BytesUtils.cpp +++ b/test/libsolidity/util/BytesUtils.cpp @@ -36,11 +36,9 @@ using namespace solidity; using namespace solidity::util; -using namespace solidity::langutil; using namespace solidity::frontend; using namespace solidity::frontend::test; using namespace std; -using namespace soltest; bytes BytesUtils::alignLeft(bytes _bytes) { diff --git a/test/libsolidity/util/ContractABIUtils.cpp b/test/libsolidity/util/ContractABIUtils.cpp index 520569907..70e20c185 100644 --- a/test/libsolidity/util/ContractABIUtils.cpp +++ b/test/libsolidity/util/ContractABIUtils.cpp @@ -41,7 +41,6 @@ using namespace solidity::util; using namespace solidity::langutil; using namespace solidity::frontend::test; using namespace std; -using namespace soltest; namespace { diff --git a/test/libsolidity/util/SoltestTypes.h b/test/libsolidity/util/SoltestTypes.h index 7558dbd7d..e0f6caa1f 100644 --- a/test/libsolidity/util/SoltestTypes.h +++ b/test/libsolidity/util/SoltestTypes.h @@ -16,7 +16,6 @@ #include #include -#include namespace solidity::frontend::test { diff --git a/test/libsolidity/util/TestFileParser.cpp b/test/libsolidity/util/TestFileParser.cpp index 11eef3767..fc9a92d06 100644 --- a/test/libsolidity/util/TestFileParser.cpp +++ b/test/libsolidity/util/TestFileParser.cpp @@ -34,11 +34,11 @@ #include using namespace solidity; -using namespace solidity::langutil; using namespace solidity::frontend; using namespace solidity::frontend::test; using namespace std; -using namespace soltest; + +using Token = soltest::Token; char TestFileParser::Scanner::peek() const noexcept { @@ -158,7 +158,7 @@ vector TestFileParser::parseFunctionCall return calls; } -bool TestFileParser::accept(soltest::Token _token, bool const _expect) +bool TestFileParser::accept(Token _token, bool const _expect) { if (m_scanner.currentToken() != _token) return false; @@ -167,7 +167,7 @@ bool TestFileParser::accept(soltest::Token _token, bool const _expect) return true; } -bool TestFileParser::expect(soltest::Token _token, bool const _advance) +bool TestFileParser::expect(Token _token, bool const _advance) { if (m_scanner.currentToken() != _token || m_scanner.currentToken() == Token::Invalid) throw TestParserError( @@ -484,8 +484,6 @@ void TestFileParser::Scanner::readStream(istream& _stream) void TestFileParser::Scanner::scanNextToken() { - using namespace langutil; - // Make code coverage happy. assert(formatToken(Token::NUM_TOKENS) == ""); @@ -554,12 +552,12 @@ void TestFileParser::Scanner::scanNextToken() token = selectToken(Token::String, scanString()); break; default: - if (isIdentifierStart(current())) + if (langutil::isIdentifierStart(current())) { TokenDesc detectedToken = detectKeyword(scanIdentifierOrKeyword()); token = selectToken(detectedToken.first, detectedToken.second); } - else if (isDecimalDigit(current())) + else if (langutil::isDecimalDigit(current())) { if (current() == '0' && peek() == 'x') { @@ -570,7 +568,7 @@ void TestFileParser::Scanner::scanNextToken() else token = selectToken(Token::Number, scanDecimalNumber()); } - else if (isWhiteSpace(current())) + else if (langutil::isWhiteSpace(current())) token = selectToken(Token::Whitespace); else if (isEndOfLine()) token = make_pair(Token::EOS, "EOS"); diff --git a/test/libsolidity/util/TestFileParser.h b/test/libsolidity/util/TestFileParser.h index 8178c721d..231fc969b 100644 --- a/test/libsolidity/util/TestFileParser.h +++ b/test/libsolidity/util/TestFileParser.h @@ -15,7 +15,6 @@ #pragma once #include -#include #include #include @@ -64,7 +63,6 @@ public: std::vector parseFunctionCalls(std::size_t _lineOffset); private: - using Token = soltest::Token; /** * Token scanner that is used internally to abstract away character traversal. */ @@ -92,7 +90,7 @@ private: char scanHexPart(); private: - using TokenDesc = std::pair; + using TokenDesc = std::pair; /// Advances current position in the input stream. void advance(unsigned n = 1) diff --git a/test/libsolidity/util/TestFunctionCall.cpp b/test/libsolidity/util/TestFunctionCall.cpp index 3061b5f21..e13fccf09 100644 --- a/test/libsolidity/util/TestFunctionCall.cpp +++ b/test/libsolidity/util/TestFunctionCall.cpp @@ -30,6 +30,8 @@ using namespace solidity::util; using namespace solidity::frontend::test; using namespace std; +using Token = soltest::Token; + string TestFunctionCall::format( ErrorReporter& _errorReporter, string const& _linePrefix, @@ -37,9 +39,6 @@ string TestFunctionCall::format( bool const _highlight ) const { - using namespace soltest; - using Token = soltest::Token; - stringstream stream; bool highlight = !matchesExpectation() && _highlight; @@ -279,8 +278,6 @@ string TestFunctionCall::formatFailure( bool _highlight ) const { - using Token = soltest::Token; - stringstream os; os << formatToken(Token::Failure); diff --git a/test/libsolidity/util/TestFunctionCall.h b/test/libsolidity/util/TestFunctionCall.h index 6f21fc9eb..7daac093a 100644 --- a/test/libsolidity/util/TestFunctionCall.h +++ b/test/libsolidity/util/TestFunctionCall.h @@ -17,7 +17,6 @@ #include #include -#include #include #include #include From 81c448fb4c0a59877fd019e7cb2a48b5ad2a5fde Mon Sep 17 00:00:00 2001 From: Alex Beregszaszi Date: Tue, 3 Nov 2020 20:19:02 +0000 Subject: [PATCH 2/2] Rework TestFileParser --- test/libsolidity/util/TestFileParser.cpp | 74 +++++++++++++----------- test/libsolidity/util/TestFileParser.h | 9 ++- 2 files changed, 43 insertions(+), 40 deletions(-) diff --git a/test/libsolidity/util/TestFileParser.cpp b/test/libsolidity/util/TestFileParser.cpp index fc9a92d06..675ba5f93 100644 --- a/test/libsolidity/util/TestFileParser.cpp +++ b/test/libsolidity/util/TestFileParser.cpp @@ -487,26 +487,28 @@ void TestFileParser::Scanner::scanNextToken() // Make code coverage happy. assert(formatToken(Token::NUM_TOKENS) == ""); - auto detectKeyword = [](std::string const& _literal = "") -> TokenDesc { - if (_literal == "true") return TokenDesc{Token::Boolean, _literal}; - if (_literal == "false") return TokenDesc{Token::Boolean, _literal}; - if (_literal == "ether") return TokenDesc{Token::Ether, _literal}; - if (_literal == "wei") return TokenDesc{Token::Wei, _literal}; - if (_literal == "left") return TokenDesc{Token::Left, _literal}; - if (_literal == "library") return TokenDesc{Token::Library, _literal}; - if (_literal == "right") return TokenDesc{Token::Right, _literal}; - if (_literal == "hex") return TokenDesc{Token::Hex, _literal}; - if (_literal == "FAILURE") return TokenDesc{Token::Failure, _literal}; - if (_literal == "storage") return TokenDesc{Token::Storage, _literal}; - return TokenDesc{Token::Identifier, _literal}; + auto detectKeyword = [](std::string const& _literal = "") -> std::pair { + if (_literal == "true") return {Token::Boolean, "true"}; + if (_literal == "false") return {Token::Boolean, "false"}; + if (_literal == "ether") return {Token::Ether, ""}; + if (_literal == "wei") return {Token::Wei, ""}; + if (_literal == "left") return {Token::Left, ""}; + if (_literal == "library") return {Token::Library, ""}; + if (_literal == "right") return {Token::Right, ""}; + if (_literal == "hex") return {Token::Hex, ""}; + if (_literal == "FAILURE") return {Token::Failure, ""}; + if (_literal == "storage") return {Token::Storage, ""}; + return {Token::Identifier, _literal}; }; - auto selectToken = [this](Token _token, std::optional _literal = std::nullopt) -> TokenDesc { + auto selectToken = [this](Token _token, std::string const& _literal = "") { advance(); - return make_pair(_token, _literal.has_value() ? *_literal : formatToken(_token)); + m_currentToken = _token; + m_currentLiteral = _literal; }; - TokenDesc token = make_pair(Token::Unknown, ""); + m_currentToken = Token::Unknown; + m_currentLiteral = ""; do { switch(current()) @@ -514,48 +516,48 @@ void TestFileParser::Scanner::scanNextToken() case '/': advance(); if (current() == '/') - token = selectToken(Token::Newline); + selectToken(Token::Newline); else - token = selectToken(Token::Invalid); + selectToken(Token::Invalid); break; case '-': if (peek() == '>') { advance(); - token = selectToken(Token::Arrow); + selectToken(Token::Arrow); } else - token = selectToken(Token::Sub); + selectToken(Token::Sub); break; case ':': - token = selectToken(Token::Colon); + selectToken(Token::Colon); break; case '#': - token = selectToken(Token::Comment, scanComment()); + selectToken(Token::Comment, scanComment()); break; case ',': - token = selectToken(Token::Comma); + selectToken(Token::Comma); break; case '(': - token = selectToken(Token::LParen); + selectToken(Token::LParen); break; case ')': - token = selectToken(Token::RParen); + selectToken(Token::RParen); break; case '[': - token = selectToken(Token::LBrack); + selectToken(Token::LBrack); break; case ']': - token = selectToken(Token::RBrack); + selectToken(Token::RBrack); break; case '\"': - token = selectToken(Token::String, scanString()); + selectToken(Token::String, scanString()); break; default: if (langutil::isIdentifierStart(current())) { - TokenDesc detectedToken = detectKeyword(scanIdentifierOrKeyword()); - token = selectToken(detectedToken.first, detectedToken.second); + std::tie(m_currentToken, m_currentLiteral) = detectKeyword(scanIdentifierOrKeyword()); + advance(); } else if (langutil::isDecimalDigit(current())) { @@ -563,22 +565,24 @@ void TestFileParser::Scanner::scanNextToken() { advance(); advance(); - token = selectToken(Token::HexNumber, "0x" + scanHexNumber()); + selectToken(Token::HexNumber, "0x" + scanHexNumber()); } else - token = selectToken(Token::Number, scanDecimalNumber()); + selectToken(Token::Number, scanDecimalNumber()); } else if (langutil::isWhiteSpace(current())) - token = selectToken(Token::Whitespace); + selectToken(Token::Whitespace); else if (isEndOfLine()) - token = make_pair(Token::EOS, "EOS"); + { + m_currentToken = Token::EOS; + m_currentLiteral = ""; + } else throw TestParserError("Unexpected character: '" + string{current()} + "'"); break; } } - while (token.first == Token::Whitespace); - m_currentToken = token; + while (m_currentToken == Token::Whitespace); } string TestFileParser::Scanner::scanComment() diff --git a/test/libsolidity/util/TestFileParser.h b/test/libsolidity/util/TestFileParser.h index 231fc969b..63a95dd4a 100644 --- a/test/libsolidity/util/TestFileParser.h +++ b/test/libsolidity/util/TestFileParser.h @@ -79,8 +79,8 @@ private: /// Reads character stream and creates token. void scanNextToken(); - soltest::Token currentToken() { return m_currentToken.first; } - std::string currentLiteral() { return m_currentToken.second; } + soltest::Token currentToken() { return m_currentToken; } + std::string currentLiteral() { return m_currentLiteral; } std::string scanComment(); std::string scanIdentifierOrKeyword(); @@ -90,8 +90,6 @@ private: char scanHexPart(); private: - using TokenDesc = std::pair; - /// Advances current position in the input stream. void advance(unsigned n = 1) { @@ -118,7 +116,8 @@ private: std::string m_line; std::string::const_iterator m_char; - TokenDesc m_currentToken; + std::string m_currentLiteral; + soltest::Token m_currentToken = soltest::Token::Unknown; }; bool accept(soltest::Token _token, bool const _expect = false);