2019-08-22 12:36:47 -04: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"
|
2019-08-31 15:30:36 -04:00
|
|
|
#include "spdlog/fmt/fmt.h"
|
2019-08-22 12:36:47 -04:00
|
|
|
|
|
|
|
namespace spdlog {
|
|
|
|
namespace details {
|
|
|
|
|
2019-08-22 17:16:13 -04: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-22 18:10:48 -04:00
|
|
|
class log_msg_buffer : public log_msg
|
2019-08-22 12:36:47 -04:00
|
|
|
{
|
2019-08-28 11:46:09 -04:00
|
|
|
memory_buf_t buffer;
|
2019-08-22 18:10:48 -04: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 12:36:47 -04:00
|
|
|
log_msg_buffer() = default;
|
|
|
|
|
2019-08-22 12:40:45 -04:00
|
|
|
explicit log_msg_buffer(const log_msg &orig_msg)
|
2019-08-22 18:10:48 -04:00
|
|
|
: log_msg{orig_msg}
|
2019-08-22 12:36:47 -04:00
|
|
|
{
|
2019-08-22 17:16:13 -04:00
|
|
|
buffer.append(logger_name.begin(), logger_name.end());
|
|
|
|
buffer.append(payload.begin(), payload.end());
|
2019-08-22 18:10:48 -04:00
|
|
|
update_string_views();
|
2019-08-22 12:36:47 -04:00
|
|
|
}
|
|
|
|
|
2019-08-27 13:20:15 -04:00
|
|
|
log_msg_buffer(const log_msg_buffer &other)
|
2019-08-27 13:22:07 -04:00
|
|
|
: log_msg{other}
|
2019-08-27 13:20:15 -04:00
|
|
|
{
|
|
|
|
buffer.append(logger_name.begin(), logger_name.end());
|
|
|
|
buffer.append(payload.begin(), payload.end());
|
|
|
|
update_string_views();
|
|
|
|
}
|
|
|
|
|
2019-08-22 18:10:48 -04:00
|
|
|
log_msg_buffer(log_msg_buffer &&other)
|
|
|
|
: log_msg{std::move(other)}
|
|
|
|
, buffer{std::move(other.buffer)}
|
|
|
|
{
|
|
|
|
update_string_views();
|
|
|
|
}
|
|
|
|
|
2019-09-04 18:12:27 -04:00
|
|
|
log_msg_buffer &operator=(const log_msg_buffer &other)
|
2019-09-04 17:39:11 -04:00
|
|
|
{
|
|
|
|
log_msg::operator=(other);
|
2019-09-04 18:12:27 -04:00
|
|
|
buffer.append(other.buffer.data(), other.buffer.data() + other.buffer.size());
|
2019-09-04 17:39:11 -04:00
|
|
|
update_string_views();
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2019-08-22 18:10:48 -04: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 12:36:47 -04:00
|
|
|
};
|
|
|
|
|
2019-08-22 12:38:00 -04:00
|
|
|
} // namespace details
|
2019-08-31 15:30:36 -04:00
|
|
|
} // namespace spdlog
|