aboutsummaryrefslogtreecommitdiffstats
path: root/liblangutil/SourceReferenceFormatter.cpp
diff options
context:
space:
mode:
authorChristian Parpart <christian@ethereum.org>2018-11-30 21:34:08 +0800
committerchriseth <chris@ethereum.org>2018-12-06 21:01:01 +0800
commit073b03d90c8f0648ba135f0b30d8e72fd871478f (patch)
treeb38bf2ef623bb1ac85bf9ca929ba61f76c05bd0d /liblangutil/SourceReferenceFormatter.cpp
parent6efe2a526691f42e83b11cf670ec3e7f51927b3e (diff)
downloaddexon-solidity-073b03d90c8f0648ba135f0b30d8e72fd871478f.tar
dexon-solidity-073b03d90c8f0648ba135f0b30d8e72fd871478f.tar.gz
dexon-solidity-073b03d90c8f0648ba135f0b30d8e72fd871478f.tar.bz2
dexon-solidity-073b03d90c8f0648ba135f0b30d8e72fd871478f.tar.lz
dexon-solidity-073b03d90c8f0648ba135f0b30d8e72fd871478f.tar.xz
dexon-solidity-073b03d90c8f0648ba135f0b30d8e72fd871478f.tar.zst
dexon-solidity-073b03d90c8f0648ba135f0b30d8e72fd871478f.zip
liblangutil: refactor SourceReferenceFormatter, splitting out retrieval and making use of new SourceLocation's CharStream knowledge
Diffstat (limited to 'liblangutil/SourceReferenceFormatter.cpp')
-rw-r--r--liblangutil/SourceReferenceFormatter.cpp103
1 files changed, 33 insertions, 70 deletions
diff --git a/liblangutil/SourceReferenceFormatter.cpp b/liblangutil/SourceReferenceFormatter.cpp
index 8ac05b4e..4bc47a65 100644
--- a/liblangutil/SourceReferenceFormatter.cpp
+++ b/liblangutil/SourceReferenceFormatter.cpp
@@ -30,100 +30,63 @@ using namespace langutil;
void SourceReferenceFormatter::printSourceLocation(SourceLocation const* _location)
{
- if (!_location || !_location->source)
- return; // Nothing we can print here
- auto const& scanner = m_scannerFromSourceName(_location->source->name());
- int startLine;
- int startColumn;
- tie(startLine, startColumn) = scanner.translatePositionToLineColumn(_location->start);
- int endLine;
- int endColumn;
- tie(endLine, endColumn) = scanner.translatePositionToLineColumn(_location->end);
- if (startLine == endLine)
- {
- string line = scanner.lineAtPosition(_location->start);
+ printSourceLocation(SourceReferenceExtractor::extract(_location));
+}
- int locationLength = endColumn - startColumn;
- if (locationLength > 150)
- {
- line = line.substr(0, startColumn + 35) + " ... " + line.substr(endColumn - 35);
- endColumn = startColumn + 75;
- locationLength = 75;
- }
- if (line.length() > 150)
- {
- int len = line.length();
- line = line.substr(max(0, startColumn - 35), min(startColumn, 35) + min(locationLength + 35, len - startColumn));
- if (startColumn + locationLength + 35 < len)
- line += " ...";
- if (startColumn > 35)
- {
- line = " ... " + line;
- startColumn = 40;
- }
- endColumn = startColumn + locationLength;
- }
+void SourceReferenceFormatter::printSourceLocation(SourceReference const& _ref)
+{
+ if (_ref.position.line < 0)
+ return; // Nothing we can print here
- m_stream << line << endl;
+ if (!_ref.multiline)
+ {
+ m_stream << _ref.text << endl;
+ // mark the text-range like this: ^-----^
for_each(
- line.cbegin(),
- line.cbegin() + startColumn,
- [this](char const& ch) { m_stream << (ch == '\t' ? '\t' : ' '); }
+ _ref.text.cbegin(),
+ _ref.text.cbegin() + _ref.startColumn,
+ [this](char ch) { m_stream << (ch == '\t' ? '\t' : ' '); }
);
m_stream << "^";
- if (endColumn > startColumn + 2)
- m_stream << string(endColumn - startColumn - 2, '-');
- if (endColumn > startColumn + 1)
+ if (_ref.endColumn > _ref.startColumn + 2)
+ m_stream << string(_ref.endColumn - _ref.startColumn - 2, '-');
+ if (_ref.endColumn > _ref.startColumn + 1)
m_stream << "^";
m_stream << endl;
}
else
m_stream <<
- scanner.lineAtPosition(_location->start) <<
+ _ref.text <<
endl <<
- string(startColumn, ' ') <<
+ string(_ref.startColumn, ' ') <<
"^ (Relevant source part starts here and spans across multiple lines)." <<
endl;
}
-void SourceReferenceFormatter::printSourceName(SourceLocation const* _location)
+void SourceReferenceFormatter::printSourceName(SourceReference const& _ref)
{
- if (!_location || !_location->source)
- return; // Nothing we can print here
- auto const& scanner = m_scannerFromSourceName(_location->source->name());
- int startLine;
- int startColumn;
- tie(startLine, startColumn) = scanner.translatePositionToLineColumn(_location->start);
- m_stream << _location->source->name() << ":" << (startLine + 1) << ":" << (startColumn + 1) << ": ";
+ if (_ref.position.line != -1)
+ m_stream << _ref.sourceName << ":" << (_ref.position.line + 1) << ":" << (_ref.position.column + 1) << ": ";
}
-void SourceReferenceFormatter::printExceptionInformation(
- dev::Exception const& _exception,
- string const& _name
-)
+void SourceReferenceFormatter::printExceptionInformation(dev::Exception const& _error, std::string const& _category)
{
- SourceLocation const* location = boost::get_error_info<errinfo_sourceLocation>(_exception);
- auto secondarylocation = boost::get_error_info<errinfo_secondarySourceLocation>(_exception);
+ printExceptionInformation(SourceReferenceExtractor::extract(_error, _category));
+}
- printSourceName(location);
+void SourceReferenceFormatter::printExceptionInformation(SourceReferenceExtractor::Message const& _msg)
+{
+ printSourceName(_msg.primary);
- m_stream << _name;
- if (string const* description = boost::get_error_info<errinfo_comment>(_exception))
- m_stream << ": " << *description << endl;
- else
- m_stream << endl;
+ m_stream << _msg.category << ": " << _msg.primary.message << endl;
- printSourceLocation(location);
+ printSourceLocation(_msg.primary);
- if (secondarylocation && !secondarylocation->infos.empty())
+ for (auto const& ref: _msg.secondary)
{
- for (auto info: secondarylocation->infos)
- {
- printSourceName(&info.second);
- m_stream << info.first << endl;
- printSourceLocation(&info.second);
- }
- m_stream << endl;
+ printSourceName(ref);
+ m_stream << ref.message << endl;
+ printSourceLocation(ref);
}
}