mirror of
https://github.com/gabime/spdlog.git
synced 2025-01-12 00:40:26 +08:00
sinks now parameterized by mutex T
This commit is contained in:
parent
f0622c8fb8
commit
38468e64d8
@ -1,47 +0,0 @@
|
||||
#pragma once
|
||||
|
||||
#include <iostream>
|
||||
#include <mutex>
|
||||
#include <memory>
|
||||
|
||||
#include "base_sink.h"
|
||||
|
||||
namespace c11log
|
||||
{
|
||||
namespace sinks
|
||||
{
|
||||
class console_sink: public base_sink
|
||||
{
|
||||
public:
|
||||
explicit console_sink(std::ostream& os):_ostream(os) {}
|
||||
console_sink(const console_sink&) = delete;
|
||||
console_sink& operator=(const console_sink&) = delete;
|
||||
virtual ~console_sink() = default;
|
||||
|
||||
|
||||
protected:
|
||||
virtual void _sink_it(const details::log_msg& msg) override
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(_mutex);
|
||||
_ostream << msg.formatted;
|
||||
}
|
||||
|
||||
std::ostream& _ostream;
|
||||
std::mutex _mutex;
|
||||
};
|
||||
|
||||
|
||||
inline std::shared_ptr<console_sink>& stdout_sink ()
|
||||
{
|
||||
static auto inst = std::make_shared<console_sink>(std::cout);
|
||||
return inst;
|
||||
}
|
||||
|
||||
inline std::shared_ptr<console_sink>& stderr_sink ()
|
||||
{
|
||||
static auto inst = std::make_shared<console_sink>(std::cerr);
|
||||
return inst;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
18
include/c11log/sinks/isink.h
Normal file
18
include/c11log/sinks/isink.h
Normal file
@ -0,0 +1,18 @@
|
||||
#pragma once
|
||||
|
||||
#include "../details/log_msg.h"
|
||||
|
||||
namespace c11log
|
||||
{
|
||||
namespace sinks
|
||||
{
|
||||
class isink
|
||||
{
|
||||
public:
|
||||
virtual void log(const details::log_msg& msg) = 0;
|
||||
virtual void enable(bool enabled) = 0;
|
||||
virtual bool is_enabled() = 0;
|
||||
};
|
||||
}
|
||||
}
|
||||
|
33
include/c11log/sinks/stdout_sinks.h
Normal file
33
include/c11log/sinks/stdout_sinks.h
Normal file
@ -0,0 +1,33 @@
|
||||
#pragma once
|
||||
|
||||
#include <iostream>
|
||||
#include <mutex>
|
||||
#include "ostream_sink.h"
|
||||
#include "../details/null_mutex.h"
|
||||
|
||||
namespace c11log
|
||||
{
|
||||
namespace sinks
|
||||
{
|
||||
|
||||
template <class Mutex>
|
||||
class stdout_sink : public ostream_sink<Mutex>
|
||||
{
|
||||
public:
|
||||
stdout_sink() : ostream_sink<Mutex>(std::cout) {}
|
||||
};
|
||||
|
||||
typedef stdout_sink<std::mutex> stdout_sink_mt;
|
||||
typedef stdout_sink<details::null_mutex> stdout_sink_st;
|
||||
|
||||
template <class Mutex>
|
||||
class stderr_sink : public ostream_sink<Mutex>
|
||||
{
|
||||
public:
|
||||
stderr_sink() : ostream_sink<Mutex>(std::cerr) {}
|
||||
};
|
||||
|
||||
typedef stderr_sink<std::mutex> stderr_sink_mt;
|
||||
typedef stderr_sink<details::null_mutex> stderr_sink_st;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user