Commit 65407539 authored by gabime's avatar gabime

Fixed log_msg_buffer

parent 54306068
...@@ -12,23 +12,40 @@ namespace details { ...@@ -12,23 +12,40 @@ namespace details {
// extend log_msg with internal buffer to store its payload. // extend log_msg with internal buffer to store its payload.
// this is needed since log_msg holds string_views that points to stack data. // this is needed since log_msg holds string_views that points to stack data.
struct log_msg_buffer : log_msg class log_msg_buffer : public log_msg
{ {
fmt::basic_memory_buffer<char, 200> buffer; fmt::basic_memory_buffer<char, 200> buffer;
void update_string_views()
{
logger_name = string_view_t{buffer.data(), logger_name.size()};
payload = string_view_t{logger_name.end(), payload.size()};
}
public:
log_msg_buffer() = default; log_msg_buffer() = default;
explicit log_msg_buffer(const log_msg &orig_msg) explicit log_msg_buffer(const log_msg &orig_msg)
: log_msg(orig_msg) : log_msg{orig_msg}
{ {
buffer.append(logger_name.begin(), logger_name.end()); buffer.append(logger_name.begin(), logger_name.end());
logger_name = string_view_t{buffer.data(), buffer.size()};
buffer.append(payload.begin(), payload.end()); buffer.append(payload.begin(), payload.end());
payload = string_view_t{logger_name.end(), payload.size()}; update_string_views();
} }
log_msg_buffer(log_msg_buffer &&other) = default; log_msg_buffer(log_msg_buffer &&other)
log_msg_buffer &operator=(log_msg_buffer &&other) = default; : log_msg{std::move(other)}
, buffer{std::move(other.buffer)}
{
update_string_views();
}
log_msg_buffer &operator=(log_msg_buffer &&other)
{
log_msg::operator=(std::move(other));
buffer = std::move(other.buffer);
update_string_views();
return *this;
}
}; };
} // namespace details } // namespace details
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment