BubbleProfiler
0.3.0
by Peter Athron, Csaba Balazs, Michael Bardsley, Andrew Fowlie, Dylan Harries & Graham White
Main Page
Related Pages
Namespaces
Classes
Files
Examples
File List
File Members
include
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
40
class
Default_log_message
:
public
Log_message
{
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
53
Log_level
level{
Log_level::Trace
};
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
BubbleProfiler::logging::Default_log_message
Definition:
log_message.hpp:40
BubbleProfiler::logging::Log_level::Trace
BubbleProfiler::logging::to_log_level_string
std::string to_log_level_string(Log_level)
Definition:
log_message.cpp:28
BubbleProfiler::logging::Default_log_message::get_log_level
Log_level get_log_level() const override
Definition:
log_message.hpp:46
BubbleProfiler::logging::Default_log_message::Time
std::chrono::time_point< Clock > Time
Definition:
log_message.hpp:51
BubbleProfiler::logging::Log_level::Warning
BubbleProfiler::logging::Log_level::Fatal
BubbleProfiler::logging::Log_message
Definition:
log_message.hpp:32
BubbleProfiler::logging::Default_log_message::Clock
std::chrono::system_clock Clock
Definition:
log_message.hpp:50
BubbleProfiler::logging::Log_level
Log_level
Definition:
log_message.hpp:28
BubbleProfiler::logging::Log_level::Info
BubbleProfiler::logging::Log_level::Debug
BubbleProfiler::logging::Log_level::Error
BubbleProfiler
Definition:
action.hpp:33
BubbleProfiler::logging::Default_log_message::Default_log_message
Default_log_message(Log_level level_, const std::string &message_)
Definition:
log_message.hpp:42
Generated on Wed Jan 2 2019 13:08:19 for BubbleProfiler by
1.8.11