From ea7325d2d2716703d458f520e3cc48a421730094 Mon Sep 17 00:00:00 2001 From: chriseth Date: Fri, 1 Apr 2016 00:54:07 +0200 Subject: Remove code duplication in source references formatter. --- libsolidity/interface/SourceReferenceFormatter.cpp | 49 +++++++++------------- 1 file changed, 20 insertions(+), 29 deletions(-) (limited to 'libsolidity/interface/SourceReferenceFormatter.cpp') 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 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 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(_exception); auto secondarylocation = boost::get_error_info(_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(_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; } -- cgit