| 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 | } |