1 |
#pragma once |
2 |
#include <plog/Record.h> |
3 |
#include <plog/Util.h> |
4 |
#include <iomanip> |
5 |
|
6 |
namespace plog |
7 |
{ |
8 |
class TxtFormatter |
9 |
{ |
10 |
public: |
11 |
static util::nstring header() |
12 |
{ |
13 |
return util::nstring(); |
14 |
} |
15 |
|
16 |
static util::nstring format(const Record& record) |
17 |
{ |
18 |
tm t; |
19 |
util::localtime_s(&t, &record.getTime().time); |
20 |
|
21 |
util::nstringstream ss; |
22 |
ss << t.tm_year + 1900 << "-" << std::setfill(PLOG_NSTR('0')) << std::setw(2) << t.tm_mon + 1 << PLOG_NSTR("-") << std::setfill(PLOG_NSTR('0')) << std::setw(2) << t.tm_mday << PLOG_NSTR(" "); |
23 |
ss << std::setfill(PLOG_NSTR('0')) << std::setw(2) << t.tm_hour << PLOG_NSTR(":") << std::setfill(PLOG_NSTR('0')) << std::setw(2) << t.tm_min << PLOG_NSTR(":") << std::setfill(PLOG_NSTR('0')) << std::setw(2) << t.tm_sec << PLOG_NSTR(".") << std::setfill(PLOG_NSTR('0')) << std::setw(3) << record.getTime().millitm << PLOG_NSTR(" "); |
24 |
ss << std::setfill(PLOG_NSTR(' ')) << std::setw(5) << std::left << severityToString(record.getSeverity()) << PLOG_NSTR(" "); |
25 |
ss << PLOG_NSTR("[") << record.getTid() << PLOG_NSTR("] "); |
26 |
ss << PLOG_NSTR("[") << record.getFunc() << PLOG_NSTR("@") << record.getLine() << PLOG_NSTR("] "); |
27 |
ss << record.getMessage() << PLOG_NSTR("\n"); |
28 |
|
29 |
return ss.str(); |
30 |
} |
31 |
}; |
32 |
} |