/*
Ousía
Copyright (C) 2014, 2015 Benjamin Paaßen, Andreas Stöckel
This program 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.
This program 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 this program. If not, see .
*/
/**
* @file TerminalLogger.hpp
*
* Provides the TerminalLogger class, which is used to log messages to an output
* stream, possibly a Terminal.
*
* @author Andreas Stöckel (astoecke@techfak.uni-bielefeld.de)
*/
#ifndef _OUSIA_TERMINAL_LOGGER_HPP_
#define _OUSIA_TERMINAL_LOGGER_HPP_
#include
#include
namespace ousia {
/**
* Class extending the Logger class and printing (possibly colored) log messages
* to the given stream.
*/
class TerminalLogger : public ConcreteLogger {
private:
/**
* Reference to the target output stream.
*/
std::ostream &os;
/**
* If true, the TerminalLogger will use colors to make the log messages
* prettier.
*/
bool useColor;
protected:
void processMessage(const Message &msg) override;
public:
/**
* Constructor of the TerminalLogger class.
*
* @param os is the output stream the log messages should be logged to.
* Should be set to std::cerr in most cases.
* @param useColor if true, the TerminalLogger class will do its best to
* use ANSI/VT100 control sequences for colored log messages.
* @param minSeverity is the minimum severity below which log messages
* are discarded.
*/
TerminalLogger(std::ostream &os, bool useColor = false,
Severity minSeverity = DEFAULT_MIN_SEVERITY)
: ConcreteLogger(minSeverity), os(os), useColor(useColor)
{
}
};
}
#endif /* _OUSIA_TERMINAL_LOGGER_HPP_ */