Merge pull request #6059 from ethereum/soltest-langutil-commons

[soltest] Share code with langutil
This commit is contained in:
chriseth 2019-02-21 09:52:55 +01:00 committed by GitHub
commit e7a8fed01b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 71 additions and 59 deletions

View File

@ -1,5 +1,6 @@
# Solidity Commons Library (Solidity related sharing bits between libsolidity and libyul) # Solidity Commons Library (Solidity related sharing bits between libsolidity and libyul)
set(sources set(sources
Common.h
CharStream.cpp CharStream.cpp
CharStream.h CharStream.h
ErrorReporter.cpp ErrorReporter.cpp

63
liblangutil/Common.h Normal file
View File

@ -0,0 +1,63 @@
/*
This file is part of solidity.
solidity 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.
solidity 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 solidity. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
namespace langutil
{
inline bool isDecimalDigit(char c)
{
return '0' <= c && c <= '9';
}
inline bool isHexDigit(char c)
{
return
isDecimalDigit(c) ||
('a' <= c && c <= 'f') ||
('A' <= c && c <= 'F');
}
inline bool isLineTerminator(char c)
{
return c == '\n';
}
inline bool isWhiteSpace(char c)
{
return c == ' ' || c == '\n' || c == '\t' || c == '\r';
}
inline bool isIdentifierStart(char c)
{
return c == '_' || c == '$' || ('a' <= c && c <= 'z') || ('A' <= c && c <= 'Z');
}
inline bool isIdentifierPart(char c)
{
return isIdentifierStart(c) || isDecimalDigit(c);
}
inline int hexValue(char c)
{
if (c >= '0' && c <= '9')
return c - '0';
else if (c >= 'a' && c <= 'f')
return c - 'a' + 10;
else if (c >= 'A' && c <= 'F')
return c - 'A' + 10;
else return -1;
}
}

View File

@ -50,6 +50,7 @@
* Solidity scanner. * Solidity scanner.
*/ */
#include <liblangutil/Common.h>
#include <liblangutil/Exceptions.h> #include <liblangutil/Exceptions.h>
#include <liblangutil/Scanner.h> #include <liblangutil/Scanner.h>
#include <algorithm> #include <algorithm>
@ -61,47 +62,6 @@ using namespace std;
namespace langutil namespace langutil
{ {
namespace
{
bool isDecimalDigit(char c)
{
return '0' <= c && c <= '9';
}
bool isHexDigit(char c)
{
return
isDecimalDigit(c) ||
('a' <= c && c <= 'f') ||
('A' <= c && c <= 'F');
}
bool isLineTerminator(char c)
{
return c == '\n';
}
bool isWhiteSpace(char c)
{
return c == ' ' || c == '\n' || c == '\t' || c == '\r';
}
bool isIdentifierStart(char c)
{
return c == '_' || c == '$' || ('a' <= c && c <= 'z') || ('A' <= c && c <= 'Z');
}
bool isIdentifierPart(char c)
{
return isIdentifierStart(c) || isDecimalDigit(c);
}
int hexValue(char c)
{
if (c >= '0' && c <= '9')
return c - '0';
else if (c >= 'a' && c <= 'f')
return c - 'a' + 10;
else if (c >= 'A' && c <= 'F')
return c - 'A' + 10;
else return -1;
}
} // end anonymous namespace
std::string to_string(ScannerError _errorCode) std::string to_string(ScannerError _errorCode)
{ {
switch (_errorCode) switch (_errorCode)

View File

@ -16,8 +16,8 @@
*/ */
#include <test/libsolidity/util/TestFileParser.h> #include <test/libsolidity/util/TestFileParser.h>
#include <test/Options.h> #include <test/Options.h>
#include <liblangutil/Common.h>
#include <boost/algorithm/string.hpp> #include <boost/algorithm/string.hpp>
#include <boost/algorithm/string/predicate.hpp> #include <boost/algorithm/string/predicate.hpp>
#include <boost/optional.hpp> #include <boost/optional.hpp>
@ -33,18 +33,6 @@ using namespace dev::solidity::test;
using namespace std; using namespace std;
using namespace soltest; using namespace soltest;
namespace
{
bool isIdentifierStart(char c)
{
return c == '_' || c == '$' || ('a' <= c && c <= 'z') || ('A' <= c && c <= 'Z');
}
bool isIdentifierPart(char c)
{
return isIdentifierStart(c) || isdigit(c);
}
}
vector<dev::solidity::test::FunctionCall> TestFileParser::parseFunctionCalls() vector<dev::solidity::test::FunctionCall> TestFileParser::parseFunctionCalls()
{ {
vector<FunctionCall> calls; vector<FunctionCall> calls;
@ -354,14 +342,14 @@ void TestFileParser::Scanner::scanNextToken()
token = selectToken(Token::RParen); token = selectToken(Token::RParen);
break; break;
default: default:
if (isIdentifierStart(current())) if (langutil::isIdentifierStart(current()))
{ {
TokenDesc detectedToken = detectKeyword(scanIdentifierOrKeyword()); TokenDesc detectedToken = detectKeyword(scanIdentifierOrKeyword());
token = selectToken(detectedToken.first, detectedToken.second); token = selectToken(detectedToken.first, detectedToken.second);
} }
else if (isdigit(current())) else if (langutil::isDecimalDigit(current()))
token = selectToken(Token::Number, scanNumber()); token = selectToken(Token::Number, scanNumber());
else if (isspace(current())) else if (langutil::isWhiteSpace(current()))
token = selectToken(Token::Whitespace); token = selectToken(Token::Whitespace);
else if (isEndOfLine()) else if (isEndOfLine())
token = selectToken(Token::EOS); token = selectToken(Token::EOS);
@ -389,7 +377,7 @@ string TestFileParser::Scanner::scanIdentifierOrKeyword()
{ {
string identifier; string identifier;
identifier += current(); identifier += current();
while (isIdentifierPart(peek())) while (langutil::isIdentifierPart(peek()))
{ {
advance(); advance();
identifier += current(); identifier += current();
@ -401,7 +389,7 @@ string TestFileParser::Scanner::scanNumber()
{ {
string number; string number;
number += current(); number += current();
while (isdigit(peek())) while (langutil::isDecimalDigit(peek()))
{ {
advance(); advance();
number += current(); number += current();