/* 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 . */ // SPDX-License-Identifier: GPL-3.0 /** * Formatting functions for errors referencing positions and locations in the source. */ #pragma once #include #include #include #include #include #include namespace solidity::langutil { class CharStream; class CharStreamProvider; struct SourceLocation; class SourceReferenceFormatter { public: SourceReferenceFormatter( std::ostream& _stream, CharStreamProvider const& _charStreamProvider, bool _colored, bool _withErrorIds ): m_stream(_stream), m_charStreamProvider(_charStreamProvider), m_colored(_colored), m_withErrorIds(_withErrorIds) {} // WARNING: Use the xyzErrorInformation() variants over xyzExceptionInformation() when you // do have access to an Error instance. Error is implicitly convertible to util::Exception // but the conversion loses the error ID. /// Prints source location if it is given. void printSourceLocation(SourceReference const& _ref); void printExceptionInformation(SourceReferenceExtractor::Message const& _msg); void printExceptionInformation(util::Exception const& _exception, Error::Type _type); void printExceptionInformation(util::Exception const& _exception, Error::Severity _severity); void printErrorInformation(langutil::ErrorList const& _errors); void printErrorInformation(Error const& _error); static std::string formatExceptionInformation( util::Exception const& _exception, Error::Type _type, CharStreamProvider const& _charStreamProvider, bool _colored = false ) { std::ostringstream errorOutput; SourceReferenceFormatter formatter(errorOutput, _charStreamProvider, _colored, false /* _withErrorIds */); formatter.printExceptionInformation(_exception, _type); return errorOutput.str(); } static std::string formatExceptionInformation( util::Exception const& _exception, Error::Severity _severity, CharStreamProvider const& _charStreamProvider, bool _colored = false ) { std::ostringstream errorOutput; SourceReferenceFormatter formatter(errorOutput, _charStreamProvider, _colored, false /* _withErrorIds */); formatter.printExceptionInformation(_exception, _severity); return errorOutput.str(); } static std::string formatErrorInformation( Error const& _error, CharStreamProvider const& _charStreamProvider, bool _colored = false, bool _withErrorIds = false ) { std::ostringstream errorOutput; SourceReferenceFormatter formatter(errorOutput, _charStreamProvider, _colored, _withErrorIds); formatter.printErrorInformation(_error); return errorOutput.str(); } static std::string formatErrorInformation( langutil::ErrorList const& _errors, CharStreamProvider const& _charStreamProvider, bool _colored = false, bool _withErrorIds = false ) { std::ostringstream errorOutput; SourceReferenceFormatter formatter(errorOutput, _charStreamProvider, _colored, _withErrorIds); formatter.printErrorInformation(_errors); return errorOutput.str(); } static std::string formatErrorInformation(Error const& _error, CharStream const& _charStream); /// The default text color for printing error messages of a given severity in the terminal. /// Only suitable for color schemes with a dark background. static char const* errorTextColor(Error::Severity _severity); /// The default background color for highlighting source fragments corresponding to an error /// of a given severity in the terminal. /// Only suitable for color schemes with a light text. static char const* errorHighlightColor(Error::Severity _severity); private: util::AnsiColorized normalColored() const; util::AnsiColorized frameColored() const; util::AnsiColorized errorColored(langutil::Error::Severity _severity) const; util::AnsiColorized messageColored() const; util::AnsiColorized secondaryColored() const; util::AnsiColorized highlightColored() const; util::AnsiColorized diagColored() const; private: std::ostream& m_stream; CharStreamProvider const& m_charStreamProvider; bool m_colored; bool m_withErrorIds; }; }