From 3c7253d6cdc23aac36208fa87dc6571c7cb7c5ff Mon Sep 17 00:00:00 2001 From: Dark1-dev Date: Wed, 1 Mar 2023 21:33:55 +0600 Subject: Add files via upload --- Logger/initlog.cpp | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 Logger/initlog.cpp (limited to 'Logger/initlog.cpp') diff --git a/Logger/initlog.cpp b/Logger/initlog.cpp new file mode 100644 index 0000000..d852c86 --- /dev/null +++ b/Logger/initlog.cpp @@ -0,0 +1,37 @@ +#include "logger.h" + +bool Logger::init(const QString &applicationPath, + const SettingStructure &settings) +{ + // test if log directory exists + _logPath = applicationPath + "/" + _logDirectory; + QDir logDir(_logPath); + if ( ! logDir.mkpath(".") ) + { + QTextStream(stdout) << "Failed to access log directory at " + _logPath << endl + << "Please create the director and/or apply relevant permissions." << endl; + return false; + } + + // log cycling -- determine log cycling setting + const QHash logCycling = { + {"never", 0}, + {"yearly", 1}, + {"monthly", 2}, + {"weekly", 3}, + {"daily", 4} + }; + + // load log-specific settings + _cyclePeriod = logCycling.value( settings.LoggingSettings.cycle ); + _suppressLog = settings.LoggingSettings.suppressLog; + _suppressDisplay = settings.LoggingSettings.suppressDisplay; + + // cycling initialisation ("never" is also a cycle) + if ( ! cycleLogFile() ) + { + QTextStream(stdout) << "Failed to access log file " + _logFileName + " at " + _logPath << endl; + return false; + } + return true; +} -- cgit v1.2.3