mirror of
https://github.com/gabime/spdlog.git
synced 2025-01-13 17:22:06 +08:00
split to log_msg_buffer.h ito header and mpl
This commit is contained in:
parent
c1c23d1e7b
commit
5721debdf1
63
include/spdlog/details/log_msg_buffer-inl.h
Normal file
63
include/spdlog/details/log_msg_buffer-inl.h
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
// Copyright(c) 2015-present, Gabi Melman & spdlog contributors.
|
||||||
|
// Distributed under the MIT License (http://opensource.org/licenses/MIT)
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#ifndef SPDLOG_HEADER_ONLY
|
||||||
|
#include "spdlog/details/log_msg_buffer.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
namespace spdlog {
|
||||||
|
namespace details {
|
||||||
|
|
||||||
|
SPDLOG_INLINE log_msg_buffer::log_msg_buffer(const log_msg &orig_msg)
|
||||||
|
: log_msg{orig_msg}
|
||||||
|
{
|
||||||
|
buffer.append(logger_name.begin(), logger_name.end());
|
||||||
|
buffer.append(payload.begin(), payload.end());
|
||||||
|
update_string_views();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
SPDLOG_INLINE log_msg_buffer::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();
|
||||||
|
}
|
||||||
|
|
||||||
|
SPDLOG_INLINE log_msg_buffer:: log_msg_buffer(log_msg_buffer &&other)
|
||||||
|
: log_msg{std::move(other)}
|
||||||
|
, buffer{std::move(other.buffer)}
|
||||||
|
{
|
||||||
|
update_string_views();
|
||||||
|
}
|
||||||
|
|
||||||
|
SPDLOG_INLINE log_msg_buffer &log_msg_buffer::operator=(const log_msg_buffer &other)
|
||||||
|
{
|
||||||
|
log_msg::operator=(other);
|
||||||
|
buffer.append(other.buffer.data(), other.buffer.data() + other.buffer.size());
|
||||||
|
update_string_views();
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
SPDLOG_INLINE log_msg_buffer &log_msg_buffer::operator=(log_msg_buffer &&other)
|
||||||
|
{
|
||||||
|
log_msg::operator=(std::move(other));
|
||||||
|
buffer = std::move(other.buffer);
|
||||||
|
update_string_views();
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
SPDLOG_INLINE void log_msg_buffer::update_string_views()
|
||||||
|
{
|
||||||
|
logger_name = string_view_t{buffer.data(), logger_name.size()};
|
||||||
|
payload = string_view_t{logger_name.end(), payload.size()};
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace details
|
||||||
|
} // namespace spdlog
|
@ -4,7 +4,6 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "spdlog/details/log_msg.h"
|
#include "spdlog/details/log_msg.h"
|
||||||
#include "spdlog/fmt/fmt.h"
|
|
||||||
|
|
||||||
namespace spdlog {
|
namespace spdlog {
|
||||||
namespace details {
|
namespace details {
|
||||||
@ -15,54 +14,22 @@ namespace details {
|
|||||||
class log_msg_buffer : public log_msg
|
class log_msg_buffer : public log_msg
|
||||||
{
|
{
|
||||||
memory_buf_t buffer;
|
memory_buf_t buffer;
|
||||||
void update_string_views()
|
void update_string_views();
|
||||||
{
|
|
||||||
logger_name = string_view_t{buffer.data(), logger_name.size()};
|
|
||||||
payload = string_view_t{logger_name.end(), payload.size()};
|
|
||||||
}
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
log_msg_buffer() = default;
|
log_msg_buffer() = default;
|
||||||
|
explicit log_msg_buffer(const log_msg &orig_msg);
|
||||||
|
log_msg_buffer(const log_msg_buffer &other);
|
||||||
|
log_msg_buffer(log_msg_buffer &&other);
|
||||||
|
log_msg_buffer &operator=(const log_msg_buffer &other);
|
||||||
|
log_msg_buffer &operator=(log_msg_buffer &&other);
|
||||||
|
|
||||||
explicit log_msg_buffer(const log_msg &orig_msg)
|
|
||||||
: log_msg{orig_msg}
|
|
||||||
{
|
|
||||||
buffer.append(logger_name.begin(), logger_name.end());
|
|
||||||
buffer.append(payload.begin(), payload.end());
|
|
||||||
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)}
|
|
||||||
{
|
|
||||||
update_string_views();
|
|
||||||
}
|
|
||||||
|
|
||||||
log_msg_buffer &operator=(const log_msg_buffer &other)
|
|
||||||
{
|
|
||||||
log_msg::operator=(other);
|
|
||||||
buffer.append(other.buffer.data(), other.buffer.data() + other.buffer.size());
|
|
||||||
update_string_views();
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
log_msg_buffer &operator=(log_msg_buffer &&other)
|
|
||||||
{
|
|
||||||
log_msg::operator=(std::move(other));
|
|
||||||
buffer = std::move(other.buffer);
|
|
||||||
update_string_views();
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace details
|
} // namespace details
|
||||||
} // namespace spdlog
|
} // namespace spdlog
|
||||||
|
|
||||||
|
#ifdef SPDLOG_HEADER_ONLY
|
||||||
|
#include "log_msg_buffer-inl.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
#include "spdlog/details/os-inl.h"
|
#include "spdlog/details/os-inl.h"
|
||||||
#include "spdlog/details/pattern_formatter-inl.h"
|
#include "spdlog/details/pattern_formatter-inl.h"
|
||||||
#include "spdlog/details/log_msg-inl.h"
|
#include "spdlog/details/log_msg-inl.h"
|
||||||
|
#include "spdlog/details/log_msg_buffer-inl.h"
|
||||||
#include "spdlog/logger-inl.h"
|
#include "spdlog/logger-inl.h"
|
||||||
#include "spdlog/sinks/sink-inl.h"
|
#include "spdlog/sinks/sink-inl.h"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user