Add Full log writer
This commit is contained in:
parent
860af5af82
commit
e512897651
@ -18,14 +18,52 @@
|
|||||||
#ifndef WRITER_FULL_H
|
#ifndef WRITER_FULL_H
|
||||||
#define WRITER_FULL_H
|
#define WRITER_FULL_H
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
|
#include <QFile>
|
||||||
|
#include <QDir>
|
||||||
|
#include <QDateTime>
|
||||||
|
#include <QTextStream>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief A class for handling all log writing in the full logging mode.
|
||||||
|
*/
|
||||||
class WriterFull : public QObject
|
class WriterFull : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
|
/**
|
||||||
|
* @brief Constructor for full logwriter
|
||||||
|
*
|
||||||
|
* @details While this could've been a simple function, making it an object allows me to easier check runtime requirements
|
||||||
|
* when reloading the logger. It also helps split the complex stucture of a logger into easier segments.
|
||||||
|
*
|
||||||
|
* @param QPObject pointer to the parent object.
|
||||||
|
*/
|
||||||
WriterFull(QObject* parent = nullptr);;
|
WriterFull(QObject* parent = nullptr);;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Deconstructor for full logwriter.
|
||||||
|
*
|
||||||
|
* @details Doesn't really do anything, but its here for completeness sake.
|
||||||
|
*/
|
||||||
virtual ~WriterFull() {}
|
virtual ~WriterFull() {}
|
||||||
|
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* @brief Slot for u_logger to connect to when full logging is used.
|
||||||
|
* @param Preformatted QString which will be written into the logfile.
|
||||||
|
*/
|
||||||
|
void flush(const QString f_entry);
|
||||||
|
|
||||||
|
private:
|
||||||
|
/**
|
||||||
|
* @brief Filename of the logfile used. This will always be the time the server starts up.
|
||||||
|
*/
|
||||||
|
QFile l_logfile;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Directory where logfiles will be stored.
|
||||||
|
*/
|
||||||
|
QDir l_dir;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif //WRITER_FULL_H
|
#endif //WRITER_FULL_H
|
||||||
|
@ -20,5 +20,19 @@
|
|||||||
WriterFull::WriterFull(QObject* parent) :
|
WriterFull::WriterFull(QObject* parent) :
|
||||||
QObject(parent)
|
QObject(parent)
|
||||||
{
|
{
|
||||||
|
l_dir.setPath("logs/");
|
||||||
|
if (!l_dir.exists()) {
|
||||||
|
l_dir.mkpath(".");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void WriterFull::flush(const QString f_entry)
|
||||||
|
{
|
||||||
|
l_logfile.setFileName(QString("logs/%1.log").arg(QDate::currentDate().toString("yyyy-MM-dd")));
|
||||||
|
if (l_logfile.open(QIODevice::WriteOnly | QIODevice::Append)) {
|
||||||
|
QTextStream file_stream(&l_logfile);
|
||||||
|
file_stream << f_entry;
|
||||||
|
}
|
||||||
|
l_logfile.close();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user