forked from SergiusTheBest/plog
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMain.cpp
42 lines (33 loc) · 1.25 KB
/
Main.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
//
// CustomAppender - shows how to implement a custom appender that stores log messages in memory.
//
#include <plog/Log.h>
#include <plog/Formatters/FuncMessageFormatter.h>
#include <list>
namespace plog
{
template<class Formatter> // Typically a formatter is passed as a template parameter.
class MyAppender : public IAppender // All appenders MUST inherit IAppender interface.
{
public:
virtual void write(const Record& record) // This is a method from IAppender that MUST be implemented.
{
util::nstring str = Formatter::format(record); // Use the formatter to get a string from a record.
m_messageList.push_back(str); // Store a log message in a list.
}
std::list<util::nstring>& getMessageList()
{
return m_messageList;
}
private:
std::list<util::nstring> m_messageList;
};
}
int main()
{
static plog::MyAppender<plog::FuncMessageFormatter> myAppender; // Create our custom appender.
plog::init(plog::debug, &myAppender); // Initialize the logger with our appender.
LOGD << "A debug message!";
myAppender.getMessageList(); // This returns a list of stored log messages.
return 0;
}