mirror-chatterino2/src/logging/loggingchannel.cpp

77 lines
1.8 KiB
C++
Raw Normal View History

2017-06-11 09:31:45 +02:00
#include "loggingchannel.hpp"
#include "loggingmanager.hpp"
#include <QDir>
#include <ctime>
2017-04-14 17:52:22 +02:00
namespace chatterino {
namespace logging {
Channel::Channel(const QString &_channelName, const QString &_baseDirectory)
: channelName(_channelName)
, baseDirectory(_baseDirectory)
{
QDateTime now = QDateTime::currentDateTime();
2017-04-12 17:46:44 +02:00
this->fileName = this->channelName + "-" + now.toString("yyyy-MM-dd") + ".log";
// Open file handle to log file of current date
2017-04-12 17:46:44 +02:00
this->fileHandle.setFileName(this->baseDirectory + QDir::separator() + this->fileName);
this->fileHandle.open(QIODevice::Append);
this->appendLine(this->generateOpeningString(now));
}
Channel::~Channel()
{
this->appendLine(this->generateClosingString());
this->fileHandle.close();
}
2017-04-12 17:46:44 +02:00
void Channel::append(std::shared_ptr<messages::Message> message)
{
QDateTime now = QDateTime::currentDateTime();
QString str;
str.append('[');
str.append(now.toString("HH:mm:ss"));
str.append("] ");
str.append(message->loginName);
str.append(": ");
str.append(message->getSearchText());
str.append('\n');
this->appendLine(str);
}
2017-04-12 17:46:44 +02:00
QString Channel::generateOpeningString(const QDateTime &now) const
{
QString ret = QLatin1Literal("# Start logging at ");
ret.append(now.toString("yyyy-MM-dd HH:mm:ss "));
ret.append(now.timeZoneAbbreviation());
ret.append('\n');
return ret;
}
2017-04-12 17:46:44 +02:00
QString Channel::generateClosingString(const QDateTime &now) const
{
QString ret = QLatin1Literal("# Stop logging at ");
ret.append(now.toString("yyyy-MM-dd HH:mm:ss"));
ret.append(now.timeZoneAbbreviation());
ret.append('\n');
return ret;
}
2017-04-12 17:46:44 +02:00
void Channel::appendLine(const QString &line)
{
this->fileHandle.write(line.toUtf8());
this->fileHandle.flush();
}
2017-04-14 17:52:22 +02:00
} // namespace logging
} // namespace chatterino