BubbleProfiler  0.3.0
by Peter Athron, Csaba Balazs, Michael Bardsley, Andrew Fowlie, Dylan Harries & Graham White
log_message.hpp
Go to the documentation of this file.
1 /*
2  * This file is part of BubbleProfiler.
3  *
4  * BubbleProfiler is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your option) any later version.
8  *
9  * BubbleProfiler is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with BubbleProfiler. If not, see <http://www.gnu.org/licenses/>.
16  */
17 
18 #ifndef BUBBLEPROFILER_LOG_MESSAGE_HPP_INCLUDED
19 #define BUBBLEPROFILER_LOG_MESSAGE_HPP_INCLUDED
20 
21 #include <chrono>
22 #include <string>
23 
24 namespace BubbleProfiler {
25 
26 namespace logging {
27 
28 enum class Log_level { Trace, Debug, Info, Warning, Error, Fatal };
29 
30 std::string to_log_level_string(Log_level);
31 
32 class Log_message {
33 public:
34  virtual ~Log_message() = default;
35 
36  virtual Log_level get_log_level() const = 0;
37  virtual std::string get_log_entry() const = 0;
38 };
39 
41 public:
42  Default_log_message(Log_level level_, const std::string& message_)
43  : level(level_), message(message_) {}
44  virtual ~Default_log_message() = default;
45 
46  Log_level get_log_level() const override { return level; }
47  std::string get_log_entry() const override;
48 
49 private:
50  using Clock = std::chrono::system_clock;
51  using Time = std::chrono::time_point<Clock>;
52 
54  std::string message{};
55  Time log_time{Clock::now()};
56 
57  std::string get_formatted_time() const;
58 };
59 
60 } // namespace logging
61 
62 } // namespace BubbleProfiler
63 
64 #endif
std::string to_log_level_string(Log_level)
Definition: log_message.cpp:28
Log_level get_log_level() const override
Definition: log_message.hpp:46
std::chrono::time_point< Clock > Time
Definition: log_message.hpp:51
Default_log_message(Log_level level_, const std::string &message_)
Definition: log_message.hpp:42