2019-06-04 05:09:16 +08:00
|
|
|
// Copyright(c) 2015-present, Gabi Melman & spdlog contributors.
|
2019-05-13 04:36:48 +08:00
|
|
|
// Distributed under the MIT License (http://opensource.org/licenses/MIT)
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2019-05-13 05:09:00 +08:00
|
|
|
#ifndef SPDLOG_HEADER_ONLY
|
2021-07-19 05:50:51 +08:00
|
|
|
# include <spdlog/sinks/basic_file_sink.h>
|
2019-05-13 05:09:00 +08:00
|
|
|
#endif
|
|
|
|
|
2019-11-07 03:09:30 +08:00
|
|
|
#include <spdlog/common.h>
|
|
|
|
#include <spdlog/details/os.h>
|
2019-05-13 04:36:48 +08:00
|
|
|
|
|
|
|
namespace spdlog {
|
|
|
|
namespace sinks {
|
|
|
|
|
|
|
|
template<typename Mutex>
|
2021-11-16 22:41:04 +08:00
|
|
|
SPDLOG_INLINE basic_file_sink<Mutex>::basic_file_sink(const filename_t &filename, bool truncate, const file_event_handlers& event_handlers)
|
2021-11-11 00:08:24 +08:00
|
|
|
: file_helper_{event_handlers}
|
2019-05-13 04:36:48 +08:00
|
|
|
{
|
|
|
|
file_helper_.open(filename, truncate);
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename Mutex>
|
|
|
|
SPDLOG_INLINE const filename_t &basic_file_sink<Mutex>::filename() const
|
|
|
|
{
|
|
|
|
return file_helper_.filename();
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename Mutex>
|
|
|
|
SPDLOG_INLINE void basic_file_sink<Mutex>::sink_it_(const details::log_msg &msg)
|
|
|
|
{
|
2019-08-28 23:46:09 +08:00
|
|
|
memory_buf_t formatted;
|
2019-06-28 04:56:37 +08:00
|
|
|
base_sink<Mutex>::formatter_->format(msg, formatted);
|
2019-05-13 04:36:48 +08:00
|
|
|
file_helper_.write(formatted);
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename Mutex>
|
|
|
|
SPDLOG_INLINE void basic_file_sink<Mutex>::flush_()
|
|
|
|
{
|
|
|
|
file_helper_.flush();
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace sinks
|
|
|
|
} // namespace spdlog
|