spdlog/include/spdlog/details/log_msg_buffer.h

69 lines
1.8 KiB
C
Raw Normal View History

2019-08-22 19:36:47 +03:00
// Copyright(c) 2015-present, Gabi Melman & spdlog contributors.
// Distributed under the MIT License (http://opensource.org/licenses/MIT)
#pragma once
#include "spdlog/details/log_msg.h"
#include "spdlog/fmt/fmt.h"
2019-08-22 19:36:47 +03:00
namespace spdlog {
namespace details {
2019-08-23 00:16:13 +03:00
// extend log_msg with internal buffer to store its payload.
// this is needed since log_msg holds string_views that points to stack data.
2019-08-23 01:10:48 +03:00
class log_msg_buffer : public log_msg
2019-08-22 19:36:47 +03:00
{
memory_buf_t buffer;
2019-08-23 01:10:48 +03:00
void update_string_views()
{
logger_name = string_view_t{buffer.data(), logger_name.size()};
payload = string_view_t{logger_name.end(), payload.size()};
}
public:
2019-08-22 19:36:47 +03:00
log_msg_buffer() = default;
2019-08-22 19:40:45 +03:00
explicit log_msg_buffer(const log_msg &orig_msg)
2019-08-23 01:10:48 +03:00
: log_msg{orig_msg}
2019-08-22 19:36:47 +03:00
{
2019-08-23 00:16:13 +03:00
buffer.append(logger_name.begin(), logger_name.end());
buffer.append(payload.begin(), payload.end());
2019-08-23 01:10:48 +03:00
update_string_views();
2019-08-22 19:36:47 +03:00
}
log_msg_buffer(const log_msg_buffer &other)
2019-08-27 20:22:07 +03:00
: log_msg{other}
{
buffer.append(logger_name.begin(), logger_name.end());
buffer.append(payload.begin(), payload.end());
update_string_views();
}
2019-08-23 01:10:48 +03:00
log_msg_buffer(log_msg_buffer &&other)
: log_msg{std::move(other)}
, buffer{std::move(other.buffer)}
{
update_string_views();
}
2019-09-05 01:12:27 +03:00
log_msg_buffer &operator=(const log_msg_buffer &other)
{
log_msg::operator=(other);
2019-09-05 01:12:27 +03:00
buffer.append(other.buffer.data(), other.buffer.data() + other.buffer.size());
update_string_views();
return *this;
}
2019-08-23 01:10:48 +03:00
log_msg_buffer &operator=(log_msg_buffer &&other)
{
log_msg::operator=(std::move(other));
buffer = std::move(other.buffer);
update_string_views();
return *this;
}
2019-08-22 19:36:47 +03:00
};
2019-08-22 19:38:00 +03:00
} // namespace details
} // namespace spdlog