astyle
This commit is contained in:
		@@ -15,8 +15,8 @@ int main(int, char* [])
 | 
			
		||||
        logger->info() << "spdlog message #" << i << ": This is some text for your pleasure";
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	//because spdlog async logger waits for the back thread logger to finish all messages upon destrcuting,
 | 
			
		||||
	//and we want to measure only the time it took to push those messages to the backthread..
 | 
			
		||||
	abort(); 	    
 | 
			
		||||
    //because spdlog async logger waits for the back thread logger to finish all messages upon destrcuting,
 | 
			
		||||
    //and we want to measure only the time it took to push those messages to the backthread..
 | 
			
		||||
    abort();
 | 
			
		||||
    return 0;
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -45,7 +45,7 @@ int main(int argc, char* argv[])
 | 
			
		||||
        t.join();
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
	//because spdlog async logger waits for the back thread logger to finish all messages upon destrcuting,
 | 
			
		||||
	//and we want to measure only the time it took to push those messages to the backthread..
 | 
			
		||||
	abort(); 	    
 | 
			
		||||
    //because spdlog async logger waits for the back thread logger to finish all messages upon destrcuting,
 | 
			
		||||
    //and we want to measure only the time it took to push those messages to the backthread..
 | 
			
		||||
    abort();
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -80,7 +80,7 @@ int main(int argc, char* argv[])
 | 
			
		||||
        cout << "*******************************************************************************\n";
 | 
			
		||||
 | 
			
		||||
        auto rotating_mt = spdlog::rotating_logger_mt("rotating_mt", "logs/rotating_mt", file_size, rotating_files, auto_flush);
 | 
			
		||||
		bench_mt(howmany, rotating_mt, threads);
 | 
			
		||||
        bench_mt(howmany, rotating_mt, threads);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        auto daily_mt = spdlog::daily_logger_mt("daily_mt", "logs/daily_mt", auto_flush);
 | 
			
		||||
@@ -94,12 +94,12 @@ int main(int argc, char* argv[])
 | 
			
		||||
 | 
			
		||||
        spdlog::set_async_mode(howmany);
 | 
			
		||||
 | 
			
		||||
		for(int i = 0; i < 5; ++i)
 | 
			
		||||
		{
 | 
			
		||||
			auto as = spdlog::daily_logger_st("as", "logs/daily_async", auto_flush);
 | 
			
		||||
			bench_mt(howmany, as, threads);			
 | 
			
		||||
			spdlog::drop("as");
 | 
			
		||||
		}
 | 
			
		||||
        for(int i = 0; i < 5; ++i)
 | 
			
		||||
        {
 | 
			
		||||
            auto as = spdlog::daily_logger_st("as", "logs/daily_async", auto_flush);
 | 
			
		||||
            bench_mt(howmany, as, threads);
 | 
			
		||||
            spdlog::drop("as");
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    catch (std::exception &ex)
 | 
			
		||||
    {
 | 
			
		||||
 
 | 
			
		||||
@@ -61,8 +61,8 @@ int main(int, char* [])
 | 
			
		||||
        auto file_logger = spd::rotating_logger_mt("file_logger", filename, 1024 * 1024 * 5, 3);
 | 
			
		||||
 | 
			
		||||
        file_logger->info("Log file message number", 1);
 | 
			
		||||
		for(int i = 0; i < 10; ++i)
 | 
			
		||||
			file_logger->info("{} * {} equals {:>10}", i, i, i*i);
 | 
			
		||||
        for(int i = 0; i < 10; ++i)
 | 
			
		||||
            file_logger->info("{} * {} equals {:>10}", i, i, i*i);
 | 
			
		||||
 | 
			
		||||
        spd::set_pattern("*** [%H:%M:%S %z] [thread %t] %v ***");
 | 
			
		||||
        file_logger->info("This is another message with custom format");
 | 
			
		||||
 
 | 
			
		||||
@@ -74,101 +74,101 @@ class mpmc_bounded_queue
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
 | 
			
		||||
	using item_type = T;
 | 
			
		||||
	mpmc_bounded_queue(size_t buffer_size)
 | 
			
		||||
		: buffer_(new cell_t [buffer_size]),
 | 
			
		||||
		  buffer_mask_(buffer_size - 1)
 | 
			
		||||
	{
 | 
			
		||||
		//queue size must be power of two
 | 
			
		||||
		if(!((buffer_size >= 2) && ((buffer_size & (buffer_size - 1)) == 0)))
 | 
			
		||||
			throw spdlog_ex("async logger queue size must be power of two");
 | 
			
		||||
    using item_type = T;
 | 
			
		||||
    mpmc_bounded_queue(size_t buffer_size)
 | 
			
		||||
        : buffer_(new cell_t [buffer_size]),
 | 
			
		||||
          buffer_mask_(buffer_size - 1)
 | 
			
		||||
    {
 | 
			
		||||
        //queue size must be power of two
 | 
			
		||||
        if(!((buffer_size >= 2) && ((buffer_size & (buffer_size - 1)) == 0)))
 | 
			
		||||
            throw spdlog_ex("async logger queue size must be power of two");
 | 
			
		||||
 | 
			
		||||
		for (size_t i = 0; i != buffer_size; i += 1)
 | 
			
		||||
			buffer_[i].sequence_.store(i, std::memory_order_relaxed);
 | 
			
		||||
		enqueue_pos_.store(0, std::memory_order_relaxed);
 | 
			
		||||
		dequeue_pos_.store(0, std::memory_order_relaxed);
 | 
			
		||||
	}
 | 
			
		||||
        for (size_t i = 0; i != buffer_size; i += 1)
 | 
			
		||||
            buffer_[i].sequence_.store(i, std::memory_order_relaxed);
 | 
			
		||||
        enqueue_pos_.store(0, std::memory_order_relaxed);
 | 
			
		||||
        dequeue_pos_.store(0, std::memory_order_relaxed);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
	~mpmc_bounded_queue()
 | 
			
		||||
	{		
 | 
			
		||||
		delete [] buffer_;
 | 
			
		||||
	}
 | 
			
		||||
    ~mpmc_bounded_queue()
 | 
			
		||||
    {
 | 
			
		||||
        delete [] buffer_;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	bool enqueue(T&& data)
 | 
			
		||||
	{
 | 
			
		||||
		cell_t* cell;
 | 
			
		||||
		size_t pos = enqueue_pos_.load(std::memory_order_relaxed);
 | 
			
		||||
		for (;;)
 | 
			
		||||
		{		
 | 
			
		||||
			cell = &buffer_[pos & buffer_mask_];
 | 
			
		||||
			size_t seq = cell->sequence_.load(std::memory_order_acquire);
 | 
			
		||||
			intptr_t dif = (intptr_t)seq - (intptr_t)pos;
 | 
			
		||||
			if (dif == 0)
 | 
			
		||||
			{			
 | 
			
		||||
				if (enqueue_pos_.compare_exchange_weak(pos, pos + 1, std::memory_order_relaxed))
 | 
			
		||||
					break;
 | 
			
		||||
			}
 | 
			
		||||
			else if (dif < 0)
 | 
			
		||||
			{				
 | 
			
		||||
				return false;
 | 
			
		||||
			}			
 | 
			
		||||
			else
 | 
			
		||||
			{		
 | 
			
		||||
				pos = enqueue_pos_.load(std::memory_order_relaxed);
 | 
			
		||||
			}
 | 
			
		||||
		}		
 | 
			
		||||
		cell->data_ = std::move(data);
 | 
			
		||||
		cell->sequence_.store(pos + 1, std::memory_order_release);
 | 
			
		||||
		return true;
 | 
			
		||||
	}
 | 
			
		||||
    bool enqueue(T&& data)
 | 
			
		||||
    {
 | 
			
		||||
        cell_t* cell;
 | 
			
		||||
        size_t pos = enqueue_pos_.load(std::memory_order_relaxed);
 | 
			
		||||
        for (;;)
 | 
			
		||||
        {
 | 
			
		||||
            cell = &buffer_[pos & buffer_mask_];
 | 
			
		||||
            size_t seq = cell->sequence_.load(std::memory_order_acquire);
 | 
			
		||||
            intptr_t dif = (intptr_t)seq - (intptr_t)pos;
 | 
			
		||||
            if (dif == 0)
 | 
			
		||||
            {
 | 
			
		||||
                if (enqueue_pos_.compare_exchange_weak(pos, pos + 1, std::memory_order_relaxed))
 | 
			
		||||
                    break;
 | 
			
		||||
            }
 | 
			
		||||
            else if (dif < 0)
 | 
			
		||||
            {
 | 
			
		||||
                return false;
 | 
			
		||||
            }
 | 
			
		||||
            else
 | 
			
		||||
            {
 | 
			
		||||
                pos = enqueue_pos_.load(std::memory_order_relaxed);
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
        cell->data_ = std::move(data);
 | 
			
		||||
        cell->sequence_.store(pos + 1, std::memory_order_release);
 | 
			
		||||
        return true;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
	bool dequeue(T& data)
 | 
			
		||||
	{
 | 
			
		||||
		cell_t* cell;
 | 
			
		||||
		size_t pos = dequeue_pos_.load(std::memory_order_relaxed);
 | 
			
		||||
		for (;;)
 | 
			
		||||
		{
 | 
			
		||||
			cell = &buffer_[pos & buffer_mask_];
 | 
			
		||||
			size_t seq =
 | 
			
		||||
				cell->sequence_.load(std::memory_order_acquire);
 | 
			
		||||
			intptr_t dif = (intptr_t)seq - (intptr_t)(pos + 1);
 | 
			
		||||
			if (dif == 0)
 | 
			
		||||
			{
 | 
			
		||||
				if (dequeue_pos_.compare_exchange_weak(pos, pos + 1, std::memory_order_relaxed))
 | 
			
		||||
					break;
 | 
			
		||||
			}
 | 
			
		||||
			else if (dif < 0)
 | 
			
		||||
				return false;
 | 
			
		||||
			else
 | 
			
		||||
				pos = dequeue_pos_.load(std::memory_order_relaxed);
 | 
			
		||||
		}
 | 
			
		||||
		data = std::move(cell->data_);
 | 
			
		||||
		cell->sequence_.store(pos + buffer_mask_ + 1, std::memory_order_release);
 | 
			
		||||
		return true;
 | 
			
		||||
	}
 | 
			
		||||
    bool dequeue(T& data)
 | 
			
		||||
    {
 | 
			
		||||
        cell_t* cell;
 | 
			
		||||
        size_t pos = dequeue_pos_.load(std::memory_order_relaxed);
 | 
			
		||||
        for (;;)
 | 
			
		||||
        {
 | 
			
		||||
            cell = &buffer_[pos & buffer_mask_];
 | 
			
		||||
            size_t seq =
 | 
			
		||||
                cell->sequence_.load(std::memory_order_acquire);
 | 
			
		||||
            intptr_t dif = (intptr_t)seq - (intptr_t)(pos + 1);
 | 
			
		||||
            if (dif == 0)
 | 
			
		||||
            {
 | 
			
		||||
                if (dequeue_pos_.compare_exchange_weak(pos, pos + 1, std::memory_order_relaxed))
 | 
			
		||||
                    break;
 | 
			
		||||
            }
 | 
			
		||||
            else if (dif < 0)
 | 
			
		||||
                return false;
 | 
			
		||||
            else
 | 
			
		||||
                pos = dequeue_pos_.load(std::memory_order_relaxed);
 | 
			
		||||
        }
 | 
			
		||||
        data = std::move(cell->data_);
 | 
			
		||||
        cell->sequence_.store(pos + buffer_mask_ + 1, std::memory_order_release);
 | 
			
		||||
        return true;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
private:
 | 
			
		||||
	struct cell_t
 | 
			
		||||
	{
 | 
			
		||||
		std::atomic<size_t>   sequence_;
 | 
			
		||||
		T                     data_;
 | 
			
		||||
	};
 | 
			
		||||
    struct cell_t
 | 
			
		||||
    {
 | 
			
		||||
        std::atomic<size_t>   sequence_;
 | 
			
		||||
        T                     data_;
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
	static size_t const     cacheline_size = 64;
 | 
			
		||||
	typedef char            cacheline_pad_t [cacheline_size];
 | 
			
		||||
    static size_t const     cacheline_size = 64;
 | 
			
		||||
    typedef char            cacheline_pad_t [cacheline_size];
 | 
			
		||||
 | 
			
		||||
	cacheline_pad_t         pad0_;
 | 
			
		||||
	cell_t* const           buffer_;
 | 
			
		||||
	size_t const            buffer_mask_;
 | 
			
		||||
	cacheline_pad_t         pad1_;
 | 
			
		||||
	std::atomic<size_t>     enqueue_pos_;
 | 
			
		||||
	cacheline_pad_t         pad2_;
 | 
			
		||||
	std::atomic<size_t>     dequeue_pos_;
 | 
			
		||||
	cacheline_pad_t         pad3_;
 | 
			
		||||
    cacheline_pad_t         pad0_;
 | 
			
		||||
    cell_t* const           buffer_;
 | 
			
		||||
    size_t const            buffer_mask_;
 | 
			
		||||
    cacheline_pad_t         pad1_;
 | 
			
		||||
    std::atomic<size_t>     enqueue_pos_;
 | 
			
		||||
    cacheline_pad_t         pad2_;
 | 
			
		||||
    std::atomic<size_t>     dequeue_pos_;
 | 
			
		||||
    cacheline_pad_t         pad3_;
 | 
			
		||||
 | 
			
		||||
	mpmc_bounded_queue(mpmc_bounded_queue const&);
 | 
			
		||||
	void operator = (mpmc_bounded_queue const&);
 | 
			
		||||
    mpmc_bounded_queue(mpmc_bounded_queue const&);
 | 
			
		||||
    void operator = (mpmc_bounded_queue const&);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
} // ns details
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user