// ============================================================================ // Copyright (C) 2001-2016 by Jozef Starosczyk // ixen@copyhandler.com // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU Library General Public License // (version 2) as published by the Free Software Foundation; // // This program 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 Library General Public // License along with this program; if not, write to the // Free Software Foundation, Inc., // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. // ============================================================================ #ifndef __TLOGGER_H__ #define __TLOGGER_H__ #include "TLoggerLevelConfig.h" #include #include "TLogFileData.h" #include "SeverityLevels.h" #include "TMultiLoggerConfig.h" #include "TLogRecord.h" namespace logger { // do not export class TLogger { public: TLogger(const TLogFileDataPtr& spFileData, PCTSTR pszChannel); TLogFileDataPtr GetLogFileData() const; ESeverityLevel GetMinSeverity() const; TLogRecord OpenLogRecord(ESeverityLevel eLevel) const; private: TLoggerLevelConfigPtr m_spLoggerConfig; TLogFileDataPtr m_spFileData; std::wstring m_strChannel; friend class TLoggerFactory; }; using TLoggerPtr = std::unique_ptr; inline TLoggerPtr MakeLogger(const TLogFileDataPtr& spFileData, PCTSTR pszChannel) { return std::make_unique(spFileData, pszChannel); } } #define LOG(log, level) for(logger::TLogRecord rec = (log)->OpenLogRecord(level); rec.IsEnabled(); rec.Disable()) rec #define LOG_TRACE(log) if(logger::trace >= (log)->GetMinSeverity()) LOG(log, logger::trace) #define LOG_DEBUG(log) if(logger::debug >= (log)->GetMinSeverity()) LOG(log, logger::debug) #define LOG_INFO(log) if(logger::info >= (log)->GetMinSeverity()) LOG(log, logger::info) #define LOG_WARNING(log) if(logger::warning >= (log)->GetMinSeverity()) LOG(log, logger::warning) #define LOG_ERROR(log) if(logger::error >= (log)->GetMinSeverity()) LOG(log, logger::error) #define LOG_FATAL(log) if(logger::fatal >= (log)->GetMinSeverity()) LOG(log, logger::fatal) #endif