/*! * * Copyright (c) 2019-2019 Diality Inc. - All Rights Reserved. * \copyright \n * THIS CODE MAY NOT BE COPIED OR REPRODUCED IN ANY FORM, \n * IN PART OR IN WHOLE, \n * WITHOUT THE EXPLICIT PERMISSION OF THE COPYRIGHT OWNER. \n * * \file logger.h * \date 2019/09/30 * \author Behrouz NematiPour * */ #pragma once // Qt #include #include // Project #include "main.h" // Define #define _Logger Storage::Logger::I() #define LOG_DATUM(vCONTENT) Storage::Logger::I().concurrentLog(vCONTENT, Storage::Logger::LogType::eLogDatum) #define LOG_EVENT(vCONTENT) Storage::Logger::I().concurrentLog(vCONTENT, Storage::Logger::LogType::eLogEvent) #define LOG_ERROR(vCONTENT) Storage::Logger::I().concurrentLog(vCONTENT, Storage::Logger::LogType::eLogError) namespace Storage { /*! * \brief The Logger class * * \note * PLEASE BE CAREFUL THIS CLASS IS USING QtConcurrent::run * IT MEANS ANY OTHER CALL WILL BE DONE IN MAIN THREAD * AND ONLY PRIVATE VOID LOG (,) IS CALLING IN POOLED THREAD * PLEASE BE VERY CAREFUL AND DO NOT ADD SIGNAL/SLOTS OR ANY OTHER FUNCTION CALLS. * ALL THE OTHER CLASSES TO USE THIS CLASS SHOULD ONLY USE LOG_DATUM, LOG_EVENT, LOG_ERROR TO LOG */ class Logger : public QObject { Q_OBJECT public: enum LogType { eLogDatum, eLogEvent, eLogError, }; private: QDir _dir; QHash _logPathNames; QHash _logBasePathNames { { eLogDatum, "log/event/" }, // "log/datum/" { eLogEvent, "log/event/" }, { eLogError, "log/error/" }, }; QHash _logPrefix { { eLogDatum, "Datum" }, { eLogEvent, "Event" }, { eLogError, "Error" }, }; const char *_dateFormat = "yyyy_MM_dd"; const char *_timeFormat = "HH:mm:ss"; const char *_prefixSeparator = ": " ; const char *_dateSeparator = "_" ; const char *_timeSeparator = " , "; // Singleton //SINGLETON_DECL(Logger) SINGLETON(Logger) public: bool init(); void quit(); private: void initConnections(); private: // setting up void checkLogPath (); void setLogBasePath (bool vUseApplicationDirPath = false); bool setLogPath (); bool setLogPath (LogType vLogType); public slots: void concurrentLog (const QString &vContent, LogType vLogType); private: void log (const QString &vContent, LogType vLogType); }; }