sinks now parameterized by mutex T
This commit is contained in:
		@@ -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;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Reference in New Issue
	
	Block a user