Commit c55336e7 authored by gabime's avatar gabime

Better support for logger copy with backtrace

parent 13e91359
...@@ -25,7 +25,11 @@ public: ...@@ -25,7 +25,11 @@ public:
: n_messages_{n_messages}, messages_{n_messages} : 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_; return n_messages_;
} }
......
...@@ -32,6 +32,14 @@ public: ...@@ -32,6 +32,14 @@ public:
update_string_views(); 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_buffer(log_msg_buffer &&other)
: log_msg{std::move(other)} : log_msg{std::move(other)}
, buffer{std::move(other.buffer)} , buffer{std::move(other.buffer)}
......
...@@ -22,11 +22,10 @@ SPDLOG_INLINE logger::logger(const logger &other) ...@@ -22,11 +22,10 @@ SPDLOG_INLINE logger::logger(const logger &other)
, level_(other.level_.load(std::memory_order_relaxed)) , level_(other.level_.load(std::memory_order_relaxed))
, flush_level_(other.flush_level_.load(std::memory_order_relaxed)) , flush_level_(other.flush_level_.load(std::memory_order_relaxed))
, custom_err_handler_(other.custom_err_handler_) , custom_err_handler_(other.custom_err_handler_)
, tracer_(other.tracer_)
{ {
if(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