| 1 |
#pragma once |
| 2 |
#include <plog/Record.h> |
| 3 |
#include <plog/Util.h> |
| 4 |
#include <iomanip> |
| 5 |
|
| 6 |
namespace plog |
| 7 |
{ |
| 8 |
class CsvFormatter |
| 9 |
{ |
| 10 |
public: |
| 11 |
static util::nstring header() |
| 12 |
{ |
| 13 |
return PLOG_NSTR("Date;Time;Severity;TID;This;Function;Message\n"); |
| 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 << PLOG_NSTR("/") << 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 << severityToString(record.getSeverity()) << PLOG_NSTR(";"); |
| 25 |
ss << record.getTid() << PLOG_NSTR(";"); |
| 26 |
ss << record.getObject() << PLOG_NSTR(";"); |
| 27 |
ss << record.getFunc() << PLOG_NSTR("@") << record.getLine() << PLOG_NSTR(";"); |
| 28 |
|
| 29 |
util::nstring message = record.getMessage(); |
| 30 |
|
| 31 |
if (message.size() > kMaxMessageSize) |
| 32 |
{ |
| 33 |
message.resize(kMaxMessageSize); |
| 34 |
message.append(PLOG_NSTR("...")); |
| 35 |
} |
| 36 |
|
| 37 |
util::nstringstream split(message); |
| 38 |
util::nstring token; |
| 39 |
|
| 40 |
while (!split.eof()) |
| 41 |
{ |
| 42 |
std::getline(split, token, PLOG_NSTR('"')); |
| 43 |
ss << PLOG_NSTR("\"") << token << PLOG_NSTR("\""); |
| 44 |
} |
| 45 |
|
| 46 |
ss << PLOG_NSTR("\n"); |
| 47 |
|
| 48 |
return ss.str(); |
| 49 |
} |
| 50 |
|
| 51 |
static const size_t kMaxMessageSize = 32000; |
| 52 |
}; |
| 53 |
} |