Logger.hpp 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /*
  2. * Author: Patrick-Christopher Mattulat
  3. * Co-Author: Claude Sonnet 4.6 (LLM)
  4. * Company: Lynar Studios
  5. * E-Mail: webmaster@lynarstudios.com
  6. * Created: 2020-08-20
  7. * Changed: 2026-06-23
  8. *
  9. * */
  10. #ifndef LS_STD_LOGGER_HPP
  11. #define LS_STD_LOGGER_HPP
  12. #include "LogLevel.hpp"
  13. #include <ls-std/core/Class.hpp>
  14. #include <ls-std/core/interface/IWriter.hpp>
  15. #include <ls-std/io/File.hpp>
  16. #include <ls-std/io/FileOutputStream.hpp>
  17. #include <ls-std/os/dynamic-goal.hpp>
  18. #include <string>
  19. #include <string_view>
  20. /*
  21. * @doc: class(name: 'Logger', package: 'io')
  22. * @doc: io.Logger.description('This is a logger which can log to any implemented target.')
  23. * */
  24. namespace ls::standard::io
  25. {
  26. class LS_STD_DYNAMIC_GOAL Logger : public ls::standard::core::Class
  27. {
  28. public:
  29. explicit Logger(const ::std::shared_ptr<ls::standard::core::interface_type::IWriter> &_writer);
  30. ~Logger() noexcept override;
  31. void debug(const ls::standard::core::type::byte_type *_data) const;
  32. void error(const ls::standard::core::type::byte_type *_data) const;
  33. void fatal(const ls::standard::core::type::byte_type *_data) const;
  34. [[nodiscard]] ls::standard::io::LogLevel getLogLevel() const;
  35. void hideLogLevel();
  36. void hideTimestamp();
  37. void info(const ls::standard::core::type::byte_type *_data) const;
  38. void setLogLevel(const ls::standard::io::LogLevelValue &_logLevelValue);
  39. void showLogLevel();
  40. void showTimestamp();
  41. void trace(const ls::standard::core::type::byte_type *_data) const;
  42. void warn(const ls::standard::core::type::byte_type *_data) const;
  43. private:
  44. bool displayLogLevel{};
  45. bool displayTimestamp{};
  46. ls::standard::io::LogLevel logLevel{};
  47. ::std::shared_ptr<ls::standard::core::interface_type::IWriter> writer{};
  48. void _assignWriter(const ::std::shared_ptr<ls::standard::core::interface_type::IWriter> &_writer);
  49. [[nodiscard]] static ::std::string _buildCharacterChain(size_t _amount);
  50. [[nodiscard]] static ::std::string _createFillContent(::std::string_view _text);
  51. [[nodiscard]] static ::std::string _generateTimeString(const tm *_localTime);
  52. [[nodiscard]] ::std::string _getLogLevelString(const ls::standard::io::LogLevel &_logLevel) const;
  53. [[nodiscard]] ::std::string _getTimestampString() const;
  54. void _log(const ls::standard::core::type::byte_type *_data, const ls::standard::io::LogLevel &_logLevel) const;
  55. [[nodiscard]] static ::std::string _padRight(const ::std::string &_text);
  56. };
  57. }
  58. #endif