Commit c55336e7 authored by gabime's avatar gabime

Better support for logger copy with backtrace

parent 13e91359
......@@ -25,7 +25,11 @@ public:
: n_messages_{n_messages}, messages_{n_messages}
{}
size_t n_messages()
backtracer(const backtracer &other):
n_messages_{other.n_messages_}, messages_{other.messages_}
{}
size_t n_messages() const
{
return n_messages_;
}
......
......@@ -32,6 +32,14 @@ public:
update_string_views();
}
log_msg_buffer(const log_msg_buffer &other)
: log_msg{other}
{
buffer.append(logger_name.begin(), logger_name.end());
buffer.append(payload.begin(), payload.end());
update_string_views();
}
log_msg_buffer(log_msg_buffer &&other)
: log_msg{std::move(other)}
, buffer{std::move(other.buffer)}
......
......@@ -22,11 +22,10 @@ SPDLOG_INLINE logger::logger(const logger &other)
, level_(other.level_.load(std::memory_order_relaxed))
, flush_level_(other.flush_level_.load(std::memory_order_relaxed))
, custom_err_handler_(other.custom_err_handler_)
, tracer_(other.tracer_)
{
if(other.tracer_)
{
enable_backtrace(other.tracer_->n_messages());
tracer_ = std::make_shared<details::backtracer>(*other.tracer_);
}
}
......
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