aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--libsolidity/interface/SourceReferenceFormatter.cpp49
-rw-r--r--libsolidity/interface/SourceReferenceFormatter.h17
-rw-r--r--test/libsolidity/GasMeter.cpp5
3 files changed, 37 insertions, 34 deletions
diff --git a/libsolidity/interface/SourceReferenceFormatter.cpp b/libsolidity/interface/SourceReferenceFormatter.cpp
index 7b91dd2c..f09d2d45 100644
--- a/libsolidity/interface/SourceReferenceFormatter.cpp
+++ b/libsolidity/interface/SourceReferenceFormatter.cpp
@@ -33,19 +33,22 @@ namespace solidity
void SourceReferenceFormatter::printSourceLocation(
ostream& _stream,
- SourceLocation const& _location,
- Scanner const& _scanner
+ SourceLocation const* _location,
+ function<Scanner const&(string const&)> const& _scannerFromSourceName
)
{
+ if (!_location || !_location->sourceName)
+ return; // Nothing we can print here
+ auto const& scanner = _scannerFromSourceName(*_location->sourceName);
int startLine;
int startColumn;
- tie(startLine, startColumn) = _scanner.translatePositionToLineColumn(_location.start);
+ tie(startLine, startColumn) = scanner.translatePositionToLineColumn(_location->start);
int endLine;
int endColumn;
- tie(endLine, endColumn) = _scanner.translatePositionToLineColumn(_location.end);
+ tie(endLine, endColumn) = scanner.translatePositionToLineColumn(_location->end);
if (startLine == endLine)
{
- string line = _scanner.lineAtPosition(_location.start);
+ string line = scanner.lineAtPosition(_location->start);
_stream << line << endl;
for_each(
line.cbegin(),
@@ -61,7 +64,7 @@ void SourceReferenceFormatter::printSourceLocation(
}
else
_stream <<
- _scanner.lineAtPosition(_location.start) <<
+ scanner.lineAtPosition(_location->start) <<
endl <<
string(startColumn, ' ') <<
"^\n" <<
@@ -70,14 +73,17 @@ void SourceReferenceFormatter::printSourceLocation(
void SourceReferenceFormatter::printSourceName(
ostream& _stream,
- SourceLocation const& _location,
- Scanner const& _scanner
+ SourceLocation const* _location,
+ function<Scanner const&(string const&)> const& _scannerFromSourceName
)
{
+ if (!_location || !_location->sourceName)
+ return; // Nothing we can print here
+ auto const& scanner = _scannerFromSourceName(*_location->sourceName);
int startLine;
int startColumn;
- tie(startLine, startColumn) = _scanner.translatePositionToLineColumn(_location.start);
- _stream << *_location.sourceName << ":" << (startLine + 1) << ":" << (startColumn + 1) << ": ";
+ tie(startLine, startColumn) = scanner.translatePositionToLineColumn(_location->start);
+ _stream << *_location->sourceName << ":" << (startLine + 1) << ":" << (startColumn + 1) << ": ";
}
void SourceReferenceFormatter::printExceptionInformation(
@@ -89,38 +95,23 @@ void SourceReferenceFormatter::printExceptionInformation(
{
SourceLocation const* location = boost::get_error_info<errinfo_sourceLocation>(_exception);
auto secondarylocation = boost::get_error_info<errinfo_secondarySourceLocation>(_exception);
- Scanner const* scannerPtr = nullptr;
- if (location && location->sourceName)
- {
- scannerPtr = &_scannerFromSourceName(*location->sourceName);
- printSourceName(_stream, *location, *scannerPtr);
- }
+ printSourceName(_stream, location, _scannerFromSourceName);
_stream << _name;
if (string const* description = boost::get_error_info<errinfo_comment>(_exception))
_stream << ": " << *description << endl;
- if (location && location->sourceName)
- {
- scannerPtr = &_scannerFromSourceName(*location->sourceName);
- printSourceLocation(_stream, *location, *scannerPtr);
- }
+ printSourceLocation(_stream, location, _scannerFromSourceName);
if (secondarylocation && !secondarylocation->infos.empty())
{
for (auto info: secondarylocation->infos)
{
_stream << info.first << " ";
- if (!info.second.sourceName)
- {
- _stream << endl;
- continue;
- }
- scannerPtr = &_scannerFromSourceName(*info.second.sourceName);
- printSourceName(_stream, info.second, *scannerPtr);
+ printSourceName(_stream, &info.second, _scannerFromSourceName);
_stream << endl;
- printSourceLocation(_stream, info.second, *scannerPtr);
+ printSourceLocation(_stream, &info.second, _scannerFromSourceName);
}
_stream << endl;
}
diff --git a/libsolidity/interface/SourceReferenceFormatter.h b/libsolidity/interface/SourceReferenceFormatter.h
index 1fc42753..2b908c46 100644
--- a/libsolidity/interface/SourceReferenceFormatter.h
+++ b/libsolidity/interface/SourceReferenceFormatter.h
@@ -40,15 +40,26 @@ class CompilerStack; // forward
struct SourceReferenceFormatter
{
public:
- static void printSourceLocation(std::ostream& _stream, SourceLocation const& _location, Scanner const& _scanner);
+ using ScannerFromSourceNameFun = std::function<Scanner const&(std::string const&)>;
+ /// Prints source location if it is given.
+ static void printSourceLocation(
+ std::ostream& _stream,
+ SourceLocation const* _location,
+ ScannerFromSourceNameFun const& _scannerFromSourceName
+ );
static void printExceptionInformation(
std::ostream& _stream,
Exception const& _exception,
std::string const& _name,
- std::function<Scanner const&(std::string const&)> const& _scannerFromSourceName
+ ScannerFromSourceNameFun const& _scannerFromSourceName
);
private:
- static void printSourceName(std::ostream& _stream, SourceLocation const& _location, Scanner const& _scanner);
+ /// Prints source name if location is given.
+ static void printSourceName(
+ std::ostream& _stream,
+ SourceLocation const* _location,
+ ScannerFromSourceNameFun const& _scannerFromSourceName
+ );
};
}
diff --git a/test/libsolidity/GasMeter.cpp b/test/libsolidity/GasMeter.cpp
index 9f947af3..ebd5d774 100644
--- a/test/libsolidity/GasMeter.cpp
+++ b/test/libsolidity/GasMeter.cpp
@@ -120,8 +120,9 @@ BOOST_AUTO_TEST_CASE(non_overlapping_filtered_costs)
if (first->first->location().intersects(second->first->location()))
{
BOOST_CHECK_MESSAGE(false, "Source locations should not overlap!");
- SourceReferenceFormatter::printSourceLocation(cout, first->first->location(), m_compiler.scanner());
- SourceReferenceFormatter::printSourceLocation(cout, second->first->location(), m_compiler.scanner());
+ auto scannerFromSource = [&](string const&) -> Scanner const& { return m_compiler.scanner(); };
+ SourceReferenceFormatter::printSourceLocation(cout, &first->first->location(), scannerFromSource);
+ SourceReferenceFormatter::printSourceLocation(cout, &second->first->location(), scannerFromSource);
}
}
}