spdlog/include/c11log/details/log_msg.h

70 lines
1.2 KiB
C
Raw Normal View History

2014-05-06 21:11:31 +08:00
#pragma once
2014-10-10 08:36:50 +08:00
#include "../common.h"
#include "./fast_oss.h"
2014-10-10 07:46:03 +08:00
2014-05-06 21:11:31 +08:00
namespace c11log
{
namespace details
{
struct log_msg
{
log_msg() = default;
2014-05-08 07:23:07 +08:00
log_msg(level::level_enum l):
logger_name(),
level(l),
time(),
tm_time(),
raw(),
formatted() {}
log_msg(const log_msg& other):
logger_name(other.logger_name),
level(other.level),
time(other.time),
tm_time(other.tm_time),
raw(other.raw),
formatted(other.formatted) {}
log_msg(log_msg&& other)
{
swap(*this, other);
}
2014-10-15 07:24:35 +08:00
void swap(log_msg& l, log_msg& r)
{
using std::swap;
swap(l.logger_name, r.logger_name);
swap(l.level, r.level);
swap(l.time, r.time);
swap(l.tm_time, r.tm_time);
swap(l.raw, r.raw);
swap(l.formatted, r.formatted);
}
log_msg& operator=(log_msg other)
{
swap(*this, other);
return *this;
}
void clear()
{
raw.clear();
formatted.clear();
}
std::string logger_name;
level::level_enum level;
log_clock::time_point time;
std::tm tm_time;
fast_oss raw;
fast_oss formatted;
2014-05-08 07:23:07 +08:00
2014-05-06 21:11:31 +08:00
};
}
}