123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- /*
- * Author: Patrick-Christopher Mattulat
- * Company: Lynar Studios
- * E-Mail: webmaster@lynarstudios.com
- * Created: 2020-08-20
- * Changed: 2022-05-09
- *
- * */
- #include <ls_std/io/logging/Logger.hpp>
- #include <ls_std/time/Date.hpp>
- #include <ls_std/io/NewLine.hpp>
- #include <ls_std/boxing/String.hpp>
- #include <ls_std/core/exception/IllegalArgumentException.hpp>
- ls::Logger::Logger(const ::std::shared_ptr<ls::IWriter> &_writer)
- : ls::std::core::Class("Logger"),
- logLevel(ls::LogLevelValue::INFO)
- {
- this->_assignWriter(_writer);
- }
- void ls::Logger::debug(const ls::std::core::byte *_data)
- {
- if (this->logLevel >= ls::LogLevelValue::DEBUG)
- {
- this->_log(_data, ls::LogLevel(ls::LogLevelValue::DEBUG));
- }
- }
- void ls::Logger::error(const ls::std::core::byte *_data)
- {
- if (this->logLevel >= ls::LogLevelValue::ERR)
- {
- this->_log(_data, ls::LogLevel(ls::LogLevelValue::ERR));
- }
- }
- void ls::Logger::fatal(const ls::std::core::byte *_data)
- {
- if (this->logLevel >= ls::LogLevelValue::FATAL)
- {
- this->_log(_data, ls::LogLevel(ls::LogLevelValue::FATAL));
- }
- }
- ls::LogLevel ls::Logger::getLogLevel()
- {
- return this->logLevel;
- }
- void ls::Logger::info(const ls::std::core::byte *_data)
- {
- if (this->logLevel >= ls::LogLevelValue::INFO)
- {
- this->_log(_data, ls::LogLevel(ls::LogLevelValue::INFO));
- }
- }
- void ls::Logger::setLogLevel(const ls::LogLevelValue &_logLevelValue)
- {
- this->logLevel = _logLevelValue;
- }
- void ls::Logger::trace(const ls::std::core::byte *_data)
- {
- if (this->logLevel >= ls::LogLevelValue::TRACE)
- {
- this->_log(_data, ls::LogLevel(ls::LogLevelValue::TRACE));
- }
- }
- void ls::Logger::warn(const ls::std::core::byte *_data)
- {
- if (this->logLevel >= ls::LogLevelValue::WARN)
- {
- this->_log(_data, ls::LogLevel(ls::LogLevelValue::WARN));
- }
- }
- void ls::Logger::_assignWriter(const ::std::shared_ptr<ls::IWriter> &_writer)
- {
- if (_writer == nullptr)
- {
- throw ls::std::core::IllegalArgumentException{};
- }
- this->writer = _writer;
- }
- void ls::Logger::_log(const ls::std::core::byte *_data, const ls::LogLevel &_logLevel)
- {
- ls::std::time::Date date{};
- ::std::string message = "[" + date.toString() + "] " + ls::std::boxing::String{_logLevel.toString() + ":"}.padRight(10, ' ') + ::std::string(_data) + ls::NewLine::getUnixNewLine();
- this->writer->write(message);
- }
|