2014-10-01 14:22:08 +02:00
|
|
|
/*
|
|
|
|
|
Copyright 2014 Andreas Lauser
|
|
|
|
|
|
|
|
|
|
This file is part of the Open Porous Media project (OPM).
|
|
|
|
|
|
|
|
|
|
OPM 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.
|
|
|
|
|
|
|
|
|
|
OPM 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 OPM. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
*/
|
|
|
|
|
#include <stdexcept>
|
|
|
|
|
#include <sstream>
|
|
|
|
|
#include <cassert>
|
|
|
|
|
|
2015-01-06 19:31:52 +01:00
|
|
|
#include <opm/parser/eclipse/OpmLog/OpmLog.hpp>
|
2014-12-12 20:56:34 +01:00
|
|
|
#include <opm/parser/eclipse/Log/Logger.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-10-01 14:22:08 +02:00
|
|
|
namespace Opm {
|
2014-12-12 20:56:34 +01:00
|
|
|
Logger::Logger() {
|
2014-10-01 14:22:08 +02:00
|
|
|
m_numErrors = 0;
|
|
|
|
|
m_numWarnings = 0;
|
|
|
|
|
m_numNotes = 0;
|
2014-10-07 15:35:44 +02:00
|
|
|
|
|
|
|
|
setOutStream(NULL);
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
Logger::Logger(std::ostream* os) {
|
2014-10-07 15:35:44 +02:00
|
|
|
m_numErrors = 0;
|
|
|
|
|
m_numWarnings = 0;
|
|
|
|
|
m_numNotes = 0;
|
|
|
|
|
|
|
|
|
|
setOutStream(os);
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
void Logger::setOutStream(std::ostream* os) {
|
2014-10-07 15:35:44 +02:00
|
|
|
m_outStream = os;
|
2014-10-01 14:22:08 +02:00
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
size_t Logger::size() const {
|
2014-10-01 14:22:08 +02:00
|
|
|
return m_messages.size();
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
size_t Logger::numErrors() const {
|
2014-10-01 14:22:08 +02:00
|
|
|
return m_numErrors;
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
size_t Logger::numWarnings() const {
|
2014-10-01 14:22:08 +02:00
|
|
|
return m_numWarnings;
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
size_t Logger::numNotes() const {
|
2014-10-01 14:22:08 +02:00
|
|
|
return m_numNotes;
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
void Logger::addMessage(const std::string& fileName,
|
2015-01-06 19:31:52 +01:00
|
|
|
int lineNumber,
|
|
|
|
|
OpmLog::MessageType messageType,
|
|
|
|
|
const std::string& description) {
|
2014-10-01 14:22:08 +02:00
|
|
|
switch (messageType) {
|
2015-01-06 19:31:52 +01:00
|
|
|
case OpmLog::Note:
|
2014-10-01 14:22:08 +02:00
|
|
|
++m_numNotes;
|
|
|
|
|
break;
|
|
|
|
|
|
2015-01-06 19:31:52 +01:00
|
|
|
case OpmLog::Warning:
|
2014-10-01 14:22:08 +02:00
|
|
|
++m_numWarnings;
|
|
|
|
|
break;
|
|
|
|
|
|
2015-01-06 19:31:52 +01:00
|
|
|
case OpmLog::Error:
|
2014-10-01 14:22:08 +02:00
|
|
|
++m_numErrors;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
throw std::invalid_argument("Log messages must be of type Note, Warning or Error");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
m_messages.push_back(MessageTuple(fileName, lineNumber, messageType, description));
|
2014-10-07 15:35:44 +02:00
|
|
|
|
|
|
|
|
if (m_outStream) {
|
|
|
|
|
(*m_outStream) << getFormattedMessage(size() - 1) << "\n";
|
|
|
|
|
(*m_outStream) << (std::flush);
|
|
|
|
|
}
|
2014-10-01 14:22:08 +02:00
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
void Logger::addNote(const std::string& fileName,
|
2014-10-07 15:35:44 +02:00
|
|
|
int lineNumber,
|
|
|
|
|
const std::string& description) {
|
2015-01-06 19:31:52 +01:00
|
|
|
addMessage(fileName, lineNumber, OpmLog::Note, description);
|
2014-10-01 14:22:08 +02:00
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
void Logger::addWarning(const std::string& fileName,
|
2014-10-01 14:22:08 +02:00
|
|
|
int lineNumber,
|
|
|
|
|
const std::string& description) {
|
2015-01-06 19:31:52 +01:00
|
|
|
addMessage(fileName, lineNumber, OpmLog::Warning, description);
|
2014-10-01 14:22:08 +02:00
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
void Logger::addError(const std::string& fileName,
|
2014-10-01 14:22:08 +02:00
|
|
|
int lineNumber,
|
|
|
|
|
const std::string& description) {
|
2015-01-06 19:31:52 +01:00
|
|
|
addMessage(fileName, lineNumber, OpmLog::Error, description);
|
2014-10-01 14:22:08 +02:00
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
void Logger::clear()
|
2014-10-17 17:07:09 +02:00
|
|
|
{
|
|
|
|
|
m_numErrors = 0;
|
|
|
|
|
m_numWarnings = 0;
|
|
|
|
|
m_numNotes = 0;
|
|
|
|
|
|
|
|
|
|
m_messages.clear();
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
void Logger::append(const Logger &other)
|
2014-10-17 17:07:09 +02:00
|
|
|
{
|
|
|
|
|
for (size_t i = 0; i < other.size(); ++i) {
|
|
|
|
|
addMessage(other.getFileName(i),
|
|
|
|
|
other.getLineNumber(i),
|
|
|
|
|
other.getMessageType(i),
|
|
|
|
|
other.getDescription(i));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
const std::string& Logger::getFileName(size_t msgIdx) const {
|
2014-10-01 14:22:08 +02:00
|
|
|
assert(msgIdx < size());
|
|
|
|
|
return std::get<0>(m_messages[msgIdx]);
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
int Logger::getLineNumber(size_t msgIdx) const {
|
2014-10-01 14:22:08 +02:00
|
|
|
assert(msgIdx < size());
|
|
|
|
|
return std::get<1>(m_messages[msgIdx]);
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-06 19:31:52 +01:00
|
|
|
OpmLog::MessageType Logger::getMessageType(size_t msgIdx) const {
|
2014-10-01 14:22:08 +02:00
|
|
|
assert(msgIdx < size());
|
|
|
|
|
return std::get<2>(m_messages[msgIdx]);
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
const std::string& Logger::getDescription(size_t msgIdx) const {
|
2014-10-01 14:22:08 +02:00
|
|
|
assert(msgIdx < size());
|
|
|
|
|
return std::get<3>(m_messages[msgIdx]);
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
const std::string Logger::getFormattedMessage(size_t msgIdx) const {
|
2014-10-01 14:22:08 +02:00
|
|
|
std::ostringstream oss;
|
|
|
|
|
if (getLineNumber(msgIdx) > 0) {
|
|
|
|
|
oss << getFileName(msgIdx) << ":"
|
|
|
|
|
<< getLineNumber(msgIdx) << ":";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
switch (getMessageType(msgIdx)) {
|
2015-01-06 19:31:52 +01:00
|
|
|
case OpmLog::Note:
|
2014-10-01 14:22:08 +02:00
|
|
|
oss << " note:";
|
|
|
|
|
break;
|
2015-01-06 19:31:52 +01:00
|
|
|
case OpmLog::Warning:
|
2014-10-01 14:22:08 +02:00
|
|
|
oss << " warning:";
|
|
|
|
|
break;
|
2015-01-06 19:31:52 +01:00
|
|
|
case OpmLog::Error:
|
2014-10-01 14:22:08 +02:00
|
|
|
oss << " error:";
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
oss << " " << getDescription(msgIdx);
|
|
|
|
|
return oss.str();
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-12 20:56:34 +01:00
|
|
|
void Logger::printAll(std::ostream& os, size_t enabledTypes) const {
|
2014-10-01 14:22:08 +02:00
|
|
|
for (size_t i = 0; i < size(); ++i)
|
|
|
|
|
if (enabledTypes & getMessageType(i))
|
|
|
|
|
os << getFormattedMessage(i) << "\n";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace Opm
|