2023-09-24 21:56:05 +08:00
|
|
|
// Copyright(c) 2015-present, Gabi Melman & spdlog contributors.
|
|
|
|
// Distributed under the MIT License (http://opensource.org/licenses/MIT)
|
|
|
|
|
2023-09-29 05:05:17 +08:00
|
|
|
#include "spdlog/details/log_msg_buffer.h"
|
2023-09-24 21:56:05 +08:00
|
|
|
|
|
|
|
namespace spdlog {
|
|
|
|
namespace details {
|
|
|
|
|
2023-10-02 05:04:20 +08:00
|
|
|
// copy logger name and payload to buffer so can be used asynchronously
|
|
|
|
// note: source location pointers are copied without allocation since they
|
|
|
|
// are compiler generated const chars* (__FILE__, __LINE__, __FUNCTION__)
|
|
|
|
// if you pass custom strings to source location, make sure they outlive the log_msg_buffer
|
2023-09-25 01:43:14 +08:00
|
|
|
log_msg_buffer::log_msg_buffer(const log_msg &orig_msg)
|
2023-09-25 07:35:55 +08:00
|
|
|
: log_msg{orig_msg} {
|
2024-11-29 20:14:24 +08:00
|
|
|
buffer.append(logger_name);
|
|
|
|
buffer.append(payload);
|
2023-09-24 21:56:05 +08:00
|
|
|
update_string_views();
|
|
|
|
}
|
|
|
|
|
2023-09-25 01:43:14 +08:00
|
|
|
log_msg_buffer::log_msg_buffer(const log_msg_buffer &other)
|
2023-09-25 07:35:55 +08:00
|
|
|
: log_msg{other} {
|
2024-11-29 20:14:24 +08:00
|
|
|
buffer.append(logger_name);
|
|
|
|
buffer.append(payload);
|
2023-09-24 21:56:05 +08:00
|
|
|
update_string_views();
|
|
|
|
}
|
|
|
|
|
2023-09-25 01:43:14 +08:00
|
|
|
log_msg_buffer::log_msg_buffer(log_msg_buffer &&other) noexcept
|
2023-09-25 21:19:10 +08:00
|
|
|
: log_msg{other},
|
|
|
|
buffer{std::move(other.buffer)} {
|
2023-09-24 21:56:05 +08:00
|
|
|
update_string_views();
|
|
|
|
}
|
|
|
|
|
2023-09-25 07:35:55 +08:00
|
|
|
log_msg_buffer &log_msg_buffer::operator=(const log_msg_buffer &other) {
|
2023-09-24 21:56:05 +08:00
|
|
|
log_msg::operator=(other);
|
|
|
|
buffer.clear();
|
|
|
|
buffer.append(other.buffer.data(), other.buffer.data() + other.buffer.size());
|
|
|
|
update_string_views();
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2023-09-25 07:35:55 +08:00
|
|
|
log_msg_buffer &log_msg_buffer::operator=(log_msg_buffer &&other) noexcept {
|
2023-09-24 21:56:05 +08:00
|
|
|
log_msg::operator=(other);
|
|
|
|
buffer = std::move(other.buffer);
|
|
|
|
update_string_views();
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2023-09-25 07:35:55 +08:00
|
|
|
void log_msg_buffer::update_string_views() {
|
2023-09-24 21:56:05 +08:00
|
|
|
logger_name = string_view_t{buffer.data(), logger_name.size()};
|
|
|
|
payload = string_view_t{buffer.data() + logger_name.size(), payload.size()};
|
|
|
|
}
|
|
|
|
|
2023-09-25 21:40:05 +08:00
|
|
|
} // namespace details
|
|
|
|
} // namespace spdlog
|