#ifndef LOGGER_HPP #define LOGGER_HPP #include #include #include #include "Singleton_DCLP.hpp" class Logger : public Singleton_DCLP { public: class Endl {}; Logger() : m_os(nullptr), m_buffer(), m_print_time_stamp(false) {} void setStream(std::ostream* os) { m_os = os; } void setPrintTimeStamp(bool b = true) { m_print_time_stamp = b; } template Logger &operator<<(const T &x) { m_buffer << x; return *this; } Logger& operator<<(const Logger::Endl& e) { decorate(); *m_os << m_buffer.str(); *m_os << std::endl; m_buffer.str(""); return *this; } private: void decorate() { if (m_print_time_stamp) { const std::time_t timenow = std::time(nullptr); std::string s(std::ctime(&timenow)); s.pop_back(); // removing trailing \n *m_os << s << " "; } } // ostreams are not copyable, hence storing a pointer only std::ostream* m_os; std::ostringstream m_buffer; bool m_print_time_stamp; }; #define LOG *Logger::getInstance() #define END Logger::Endl(); #endif // LOGGER_HPP